From f41af04b09e9a3fb2aa14c6465c480eeee9cc046 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Joaqu=C3=ADn=20T=C3=A1rraga=20Gim=C3=A9nez?= Date: Wed, 26 Jun 2024 16:05:25 +0200 Subject: [PATCH 01/19] core: add new constructors to CellBaseException, #TASK-6427, #TASK-5318 On branch TASK-5318 Changes to be committed: modified: cellbase-core/src/main/java/org/opencb/cellbase/core/exception/CellBaseException.java --- .../opencb/cellbase/core/exception/CellBaseException.java | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/cellbase-core/src/main/java/org/opencb/cellbase/core/exception/CellBaseException.java b/cellbase-core/src/main/java/org/opencb/cellbase/core/exception/CellBaseException.java index 884c63f2ae..d1e0fc326b 100644 --- a/cellbase-core/src/main/java/org/opencb/cellbase/core/exception/CellBaseException.java +++ b/cellbase-core/src/main/java/org/opencb/cellbase/core/exception/CellBaseException.java @@ -22,5 +22,12 @@ public CellBaseException(String msg) { super(msg); } + public CellBaseException(String msg, Throwable cause) { + super(msg, cause); + } + + public CellBaseException(Throwable cause) { + super(cause); + } } From a5f57b26b009458b051f6ef60a5700810e75c40f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Joaqu=C3=ADn=20T=C3=A1rraga=20Gim=C3=A9nez?= Date: Wed, 26 Jun 2024 16:18:08 +0200 Subject: [PATCH 02/19] lib: add parser callback to use the biodata-formats' COSMIC parser, #TASK-6427, #TASK-5318 On branch TASK-5318 Changes to be committed: modified: cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/CosmicIndexer.java new file: cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/CosmicIndexerCallback.java --- .../clinical/variant/CosmicIndexer.java | 553 +----------------- .../variant/CosmicIndexerCallback.java | 266 +++++++++ 2 files changed, 276 insertions(+), 543 deletions(-) create mode 100644 cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/CosmicIndexerCallback.java diff --git a/cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/CosmicIndexer.java b/cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/CosmicIndexer.java index f8d2f16d15..4a1662cfb1 100644 --- a/cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/CosmicIndexer.java +++ b/cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/CosmicIndexer.java @@ -16,74 +16,24 @@ package org.opencb.cellbase.lib.builders.clinical.variant; -import org.apache.commons.lang3.StringUtils; -import org.opencb.biodata.models.variant.avro.*; +import org.opencb.biodata.formats.io.FileFormatException; +import org.opencb.biodata.formats.variant.cosmic.CosmicParser; +import org.opencb.cellbase.core.exception.CellBaseException; import org.opencb.cellbase.lib.EtlCommons; -import org.opencb.cellbase.lib.variant.VariantAnnotationUtils; -import org.opencb.commons.ProgressLogger; -import org.opencb.commons.utils.FileUtils; import org.rocksdb.RocksDB; import org.rocksdb.RocksDBException; -import java.io.BufferedReader; import java.io.IOException; import java.nio.file.Path; -import java.text.NumberFormat; -import java.util.*; -import java.util.regex.Matcher; -import java.util.regex.Pattern; public class CosmicIndexer extends ClinicalIndexer { private final Path cosmicFile; private final String assembly; - private Pattern mutationGRCh37GenomePositionPattern; - private Pattern snvPattern; private static final String COSMIC_VERSION = "v95"; - private static final int GENE_NAMES_COLUMN = 0; - private static final int HGNC_COLUMN = 3; - private static final int PRIMARY_SITE_COLUMN = 7; - private static final int SITE_SUBTYPE_COLUMN = 8; - private static final int PRIMARY_HISTOLOGY_COLUMN = 11; - private static final int HISTOLOGY_SUBTYPE_COLUMN = 12; - private static final int ID_COLUMN = 16; - private static final int COSM_ID_COLUMN = 17; - private static final int HGVS_COLUMN = 19; - private static final int MUTATION_DESCRIPTION_COLUMN = 21; - private static final int MUTATION_ZYGOSITY_COLUMN = 22; - private static final int FATHMM_PREDICTION_COLUMN = 29; - private static final int FATHMM_SCORE_COLUMN = 30; - private static final int MUTATION_SOMATIC_STATUS_COLUMN = 31; - private static final int PUBMED_PMID_COLUMN = 32; - private static final int SAMPLE_SOURCE_COLUMN = 34; - private static final int TUMOUR_ORIGIN_COLUMN = 35; - - private static final String HGVS_INSERTION_TAG = "ins"; - private static final String HGVS_SNV_CHANGE_SYMBOL = ">"; - private static final String HGVS_DELETION_TAG = "del"; - private static final String HGVS_DUPLICATION_TAG = "dup"; - private static final String CHROMOSOME = "CHR"; - private static final String START = "START"; - private static final String END = "END"; - private static final String REF = "REF"; - private static final String ALT = "ALT"; - private int invalidPositionLines = 0; - private int invalidSubstitutionLines = 0; - private int invalidDeletionLines = 0; - private int invalidInsertionLines = 0; - private int invalidDuplicationLines = 0; - private int invalidMutationCDSOtherReason = 0; - - private static final String VARIANT_STRING_PATTERN = "[ACGT]*"; - - private int ignoredCosmicLines = 0; - private long normaliseTime = 0; - private int rocksDBNewVariants = 0; - private int rocksDBUpdateVariants = 0; - public CosmicIndexer(Path cosmicFile, boolean normalize, Path genomeSequenceFilePath, String assembly, RocksDB rdb) throws IOException { super(genomeSequenceFilePath); @@ -91,499 +41,16 @@ public CosmicIndexer(Path cosmicFile, boolean normalize, Path genomeSequenceFile this.normalize = normalize; this.assembly = assembly; this.rdb = rdb; - - this.init(); - } - - private void init() { - mutationGRCh37GenomePositionPattern = Pattern.compile("(?<" + CHROMOSOME + ">\\S+):(?<" + START + ">\\d+)-(?<" + END + ">\\d+)"); - snvPattern = Pattern.compile("c\\.\\d+((\\+|\\-|_)\\d+)?(?<" + REF + ">(A|C|T|G)+)>(?<" + ALT + ">(A|C|T|G)+)"); } - public void index() throws RocksDBException { - logger.info("Parsing cosmic file ..."); - + public void index() throws RocksDBException, CellBaseException { + // Call COSMIC parser try { - ProgressLogger progressLogger = new ProgressLogger("Parsed COSMIC lines:", - () -> EtlCommons.countFileLines(cosmicFile), 200).setBatchSize(10000); - - long t0, t1 = 0, t2 = 0; - List evidenceEntries = new ArrayList<>(); - SequenceLocation old = null; - - BufferedReader cosmicReader = FileUtils.newBufferedReader(cosmicFile); - cosmicReader.readLine(); // First line is the header -> ignore it - String line; - while ((line = cosmicReader.readLine()) != null) { - String[] fields = line.split("\t", -1); - - t0 = System.currentTimeMillis(); - EvidenceEntry evidenceEntry = buildCosmic(fields); - t1 += System.currentTimeMillis() - t0; - - SequenceLocation sequenceLocation = parseLocation(fields); - if (old == null) { - old = sequenceLocation; - } - - if (sequenceLocation != null && parseVariant(sequenceLocation, fields)) { - if (sequenceLocation.getStart() == old.getStart() && sequenceLocation.getAlternate().equals(old.getAlternate())) { - evidenceEntries.add(evidenceEntry); - } else { - boolean success = updateRocksDB(old, evidenceEntries); - t2 += System.currentTimeMillis() - t0; - // updateRocksDB may fail (false) if normalisation process fails - if (success) { - numberIndexedRecords += evidenceEntries.size(); - } else { - ignoredCosmicLines += evidenceEntries.size(); - } - old = sequenceLocation; - evidenceEntries.clear(); - evidenceEntries.add(evidenceEntry); - } - } else { - ignoredCosmicLines++; - } - totalNumberRecords++; - progressLogger.increment(1); - - if (totalNumberRecords % 10000 == 0) { - System.out.println("totalNumberRecords = " + totalNumberRecords); - System.out.println("numberIndexedRecords = " + numberIndexedRecords + " (" - + (numberIndexedRecords * 100 / totalNumberRecords) + "%)"); - System.out.println("ignoredCosmicLines = " + ignoredCosmicLines); - System.out.println("buildCosmic = " + t1); - - System.out.println("updateRocksDB = " + t2); - System.out.println("\tnormaliseTime = " + normaliseTime); - System.out.println("\trocksDBNewVariants = " + (numberNewVariants - rocksDBNewVariants)); - System.out.println("\trocksDBUpdateVariants = " + (numberVariantUpdates - rocksDBUpdateVariants)); - System.out.println(""); - - t1 = 0; - t2 = 0; - normaliseTime = 0; - rocksDBNewVariants = numberNewVariants; - rocksDBUpdateVariants = numberVariantUpdates; - } - } - } catch (RocksDBException e) { - logger.error("Error reading/writing from/to the RocksDB index while indexing Cosmic"); - throw e; - } catch (IOException ex) { - ex.printStackTrace(); - } finally { - logger.info("Done"); - this.printSummary(); - } - } - - private void printSummary() { - logger.info("Total number of parsed Cosmic records: {}", totalNumberRecords); - logger.info("Number of indexed Cosmic records: {}", numberIndexedRecords); - logger.info("Number of new variants in Cosmic not previously indexed in RocksDB: {}", numberNewVariants); - logger.info("Number of updated variants during Cosmic indexing: {}", numberVariantUpdates); - - NumberFormat formatter = NumberFormat.getInstance(); - logger.info(formatter.format(ignoredCosmicLines) + " cosmic lines ignored: "); - if (invalidPositionLines > 0) { - logger.info("\t-" + formatter.format(invalidPositionLines) + " lines by invalid position"); - } - if (invalidSubstitutionLines > 0) { - logger.info("\t-" + formatter.format(invalidSubstitutionLines) + " lines by invalid substitution CDS"); - } - if (invalidInsertionLines > 0) { - logger.info("\t-" + formatter.format(invalidInsertionLines) + " lines by invalid insertion CDS"); - } - if (invalidDeletionLines > 0) { - logger.info("\t-" + formatter.format(invalidDeletionLines) + " lines by invalid deletion CDS"); - } - if (invalidDuplicationLines > 0) { - logger.info("\t-" + formatter.format(invalidDuplicationLines) + " lines because mutation CDS is a duplication"); - } - if (invalidMutationCDSOtherReason > 0) { - logger.info("\t-" + formatter.format(invalidMutationCDSOtherReason) - + " lines because mutation CDS is invalid for other reasons"); - } - } - - private boolean updateRocksDB(SequenceLocation sequenceLocation, List evidenceEntries) - throws RocksDBException, IOException { - // More than one variant being returned from the normalisation process would mean it's and MNV which has been decomposed - List normalisedVariantStringList = getNormalisedVariantString(sequenceLocation.getChromosome(), - sequenceLocation.getStart(), sequenceLocation.getReference(), sequenceLocation.getAlternate()); - if (normalisedVariantStringList != null) { - for (String normalisedVariantString : normalisedVariantStringList) { - VariantAnnotation variantAnnotation = getVariantAnnotation(normalisedVariantString.getBytes()); - List mergedEvidenceEntries = mergeEvidenceEntries(evidenceEntries); - addHaplotypeProperty(mergedEvidenceEntries, normalisedVariantStringList); - // IMPORTANT: COSMIC must be indexed first because of the next line !!! - variantAnnotation.setTraitAssociation(mergedEvidenceEntries); - rdb.put(normalisedVariantString.getBytes(), jsonObjectWriter.writeValueAsBytes(variantAnnotation)); - } - return true; - } - return false; - } - - private List mergeEvidenceEntries(List evidenceEntries) { - List mergedEvidenceEntries = new ArrayList<>(); - if (evidenceEntries.size() > 0) { - mergedEvidenceEntries.add(evidenceEntries.get(0)); - // For each evidence entry ... - for (int i = 1; i < evidenceEntries.size(); i++) { - boolean merged = false; - // ... check if it matches a existing evidence entry - for (EvidenceEntry mergedEvidenceEntry : mergedEvidenceEntries) { - if (sameSomaticDocument(evidenceEntries.get(i), mergedEvidenceEntry)) { - // Merge Transcripts - if (mergedEvidenceEntry.getGenomicFeatures() != null) { - if (evidenceEntries.get(i).getGenomicFeatures() != null) { - for (GenomicFeature newGenomicFeature : evidenceEntries.get(i).getGenomicFeatures()) { - if (newGenomicFeature.getFeatureType().equals(FeatureTypes.transcript)) { - boolean found = false; - for (GenomicFeature feature : mergedEvidenceEntry.getGenomicFeatures()) { - if (feature.getXrefs().get(SYMBOL).equals(newGenomicFeature.getXrefs().get(SYMBOL))) { - found = true; - } - } - if (!found) { - mergedEvidenceEntry.getGenomicFeatures().add(newGenomicFeature); - } - } - } - } - } else { - mergedEvidenceEntry.setGenomicFeatures(evidenceEntries.get(i).getGenomicFeatures()); - } - - // Merge Bibliography - // There are cosmic records which share all the fields but the bibliography. In some occassions (COSM12600) - // the redundancy is such that the document becomes much bigger than 16MB and cannot be loaded into MongoDB. - // This merge reduces redundancy. - if (mergedEvidenceEntry.getBibliography() != null) { - if (evidenceEntries.get(i).getBibliography() != null) { - Set bibliographySet = new HashSet<>(mergedEvidenceEntry.getBibliography()); - bibliographySet.addAll(new HashSet<>(evidenceEntries.get(i).getBibliography())); - mergedEvidenceEntry.setBibliography(new ArrayList<>(bibliographySet)); - } - } else { - mergedEvidenceEntry.setBibliography(evidenceEntries.get(i).getBibliography()); - } - - merged = true; - break; - } - } - if (!merged) { - mergedEvidenceEntries.add(evidenceEntries.get(i)); - } - } - } - - return mergedEvidenceEntries; - } - - public boolean sameSomaticDocument(EvidenceEntry evidenceEntry1, EvidenceEntry evidenceEntry2) { - if (evidenceEntry1 == evidenceEntry2) { - return true; - } - if (evidenceEntry2 == null || evidenceEntry1.getClass() != evidenceEntry2.getClass()) { - return false; - } - - if (evidenceEntry1.getSource() != null ? !evidenceEntry1.getSource().equals(evidenceEntry2.getSource()) - : evidenceEntry2.getSource() != null) { - return false; - } - if (evidenceEntry1.getSomaticInformation() != null - ? !evidenceEntry1.getSomaticInformation().equals(evidenceEntry2.getSomaticInformation()) - : evidenceEntry2.getSomaticInformation() != null) { - return false; - } - if (evidenceEntry1.getId() != null - ? !evidenceEntry1.getId().equals(evidenceEntry2.getId()) : evidenceEntry2.getId() != null) { - return false; - } - if (evidenceEntry1.getAlleleOrigin() != null - ? !evidenceEntry1.getAlleleOrigin().equals(evidenceEntry2.getAlleleOrigin()) - : evidenceEntry2.getAlleleOrigin() != null) { - return false; - } - if (evidenceEntry1.getGenomicFeatures() != null - ? !evidenceEntry1.getGenomicFeatures().equals(evidenceEntry2.getGenomicFeatures()) - : evidenceEntry2.getGenomicFeatures() != null) { - return false; - } - if (evidenceEntry1.getAdditionalProperties() != null - ? !evidenceEntry1.getAdditionalProperties().equals(evidenceEntry2.getAdditionalProperties()) - : evidenceEntry2.getAdditionalProperties() != null) { - return false; - } - - return true; - } - - /** - * Check whether the variant is valid and parse it. - * - * @return true if valid mutation, false otherwise - */ - private boolean parseVariant(SequenceLocation sequenceLocation, String[] fields) { - boolean validVariant = false; - String mutationCds = fields[HGVS_COLUMN]; - VariantType variantType = getVariantType(mutationCds); - if (variantType != null) { - switch (variantType) { - case SNV: - validVariant = parseSnv(mutationCds, sequenceLocation); - if (!validVariant) { - invalidSubstitutionLines++; - } - break; - case DELETION: - validVariant = parseDeletion(mutationCds, sequenceLocation); - if (!validVariant) { - invalidDeletionLines++; - } - break; - case INSERTION: - validVariant = parseInsertion(mutationCds, sequenceLocation); - if (!validVariant) { - invalidInsertionLines++; - } - break; - case DUPLICATION: - validVariant = parseDuplication(mutationCds); - if (!validVariant) { - invalidDuplicationLines++; - } - break; - default: - System.out.println("variantType = " + variantType); - validVariant = false; - invalidMutationCDSOtherReason++; - } - } - - return validVariant; - } - - private VariantType getVariantType(String mutationCds) { - if (mutationCds.contains(HGVS_SNV_CHANGE_SYMBOL)) { - return VariantType.SNV; - } else if (mutationCds.contains(HGVS_DELETION_TAG)) { - return VariantType.DELETION; - } else if (mutationCds.contains(HGVS_INSERTION_TAG)) { - return VariantType.INSERTION; - } else if (mutationCds.contains(HGVS_DUPLICATION_TAG)) { - return VariantType.DUPLICATION; - } else { - return null; - } - } - - private boolean parseDuplication(String dup) { - // TODO: The only Duplication in Cosmic V70 is a structural variation that is not going to be serialized - return false; - } - - private boolean parseInsertion(String mutationCds, SequenceLocation sequenceLocation) { - boolean validVariant = true; - String[] insParts = mutationCds.split("ins"); - - if (insParts.length > 1) { - String insertedNucleotides = insParts[1]; - if (insertedNucleotides.matches("\\d+") || !insertedNucleotides.matches(VARIANT_STRING_PATTERN)) { - //c.503_508ins30 - validVariant = false; - } else { - sequenceLocation.setReference(""); - sequenceLocation.setAlternate(getPositiveStrandString(insertedNucleotides, sequenceLocation.getStrand())); - } - } else { - validVariant = false; - } - - return validVariant; - } - - private boolean parseDeletion(String mutationCds, SequenceLocation sequenceLocation) { - boolean validVariant = true; - String[] mutationCDSArray = mutationCds.split("del"); - - // For deletions, only deletions of, at most, deletionLength nucleotide are allowed - if (mutationCDSArray.length < 2) { // c.503_508del (usually, deletions of several nucleotides) - // TODO: allow these variants - validVariant = false; - } else if (mutationCDSArray[1].matches("\\d+") - || !mutationCDSArray[1].matches(VARIANT_STRING_PATTERN)) { // Avoid allele strings containing Ns, for example - validVariant = false; - } else { - sequenceLocation.setReference(getPositiveStrandString(mutationCDSArray[1], sequenceLocation.getStrand())); - sequenceLocation.setAlternate(""); - } - - return validVariant; - } - - private boolean parseSnv(String mutationCds, SequenceLocation sequenceLocation) { - boolean validVariant = true; - Matcher snvMatcher = snvPattern.matcher(mutationCds); - - if (snvMatcher.matches()) { - String ref = snvMatcher.group(REF); - String alt = snvMatcher.group(ALT); - if (!ref.equalsIgnoreCase("N") && !alt.equalsIgnoreCase("N")) { - sequenceLocation.setReference(getPositiveStrandString(ref, sequenceLocation.getStrand())); - sequenceLocation.setAlternate(getPositiveStrandString(alt, sequenceLocation.getStrand())); - } else { - validVariant = false; - } - } else { - validVariant = false; - } - - return validVariant; - } - - private String getPositiveStrandString(String alleleString, String strand) { - if (strand.equals("-")) { - return reverseComplementary(alleleString); - } else { - return alleleString; - } - } - - private String reverseComplementary(String alleleString) { - char[] reverseAlleleString = new StringBuilder(alleleString).reverse().toString().toCharArray(); - for (int i = 0; i < reverseAlleleString.length; i++) { - reverseAlleleString[i] = VariantAnnotationUtils.COMPLEMENTARY_NT.get(reverseAlleleString[i]); - } - - return String.valueOf(reverseAlleleString); - } - - private EvidenceEntry buildCosmic(String[] fields) { - String id = fields[ID_COLUMN]; - String url = "https://cancer.sanger.ac.uk/cosmic/search?q=" + id; - - EvidenceSource evidenceSource = new EvidenceSource(EtlCommons.COSMIC_DATA, COSMIC_VERSION, null); - SomaticInformation somaticInformation = getSomaticInformation(fields); - List genomicFeatureList = getGenomicFeature(fields); - - List additionalProperties = new ArrayList<>(); - additionalProperties.add(new Property("COSM_ID", "Legacy COSM ID", fields[COSM_ID_COLUMN])); - additionalProperties.add(new Property("MUTATION_DESCRIPTION", "Description", fields[MUTATION_DESCRIPTION_COLUMN])); - if (StringUtils.isNotEmpty(fields[MUTATION_ZYGOSITY_COLUMN])) { - additionalProperties.add(new Property("MUTATION_ZYGOSITY", "Mutation Zygosity", fields[MUTATION_ZYGOSITY_COLUMN])); - } - additionalProperties.add(new Property("FATHMM_PREDICTION", "FATHMM Prediction", fields[FATHMM_PREDICTION_COLUMN])); - additionalProperties.add(new Property("FATHMM_SCORE", "FATHMM Score", "0" + fields[FATHMM_SCORE_COLUMN])); - additionalProperties.add(new Property("MUTATION_SOMATIC_STATUS", "Mutation Somatic Status", - fields[MUTATION_SOMATIC_STATUS_COLUMN])); - - List bibliography = getBibliography(fields[PUBMED_PMID_COLUMN]); - - return new EvidenceEntry(evidenceSource, Collections.emptyList(), somaticInformation, - url, id, assembly, - getAlleleOriginList(Collections.singletonList(fields[MUTATION_SOMATIC_STATUS_COLUMN])), - Collections.emptyList(), genomicFeatureList, null, null, null, null, - EthnicCategory.Z, null, null, null, additionalProperties, bibliography); - } - - private SomaticInformation getSomaticInformation(String[] fields) { - String primarySite = null; - if (!EtlCommons.isMissing(fields[PRIMARY_SITE_COLUMN])) { - primarySite = fields[PRIMARY_SITE_COLUMN].replace("_", " "); - } - String siteSubtype = null; - if (!EtlCommons.isMissing(fields[SITE_SUBTYPE_COLUMN])) { - siteSubtype = fields[SITE_SUBTYPE_COLUMN].replace("_", " "); - } - String primaryHistology = null; - if (!EtlCommons.isMissing(fields[PRIMARY_HISTOLOGY_COLUMN])) { - primaryHistology = fields[PRIMARY_HISTOLOGY_COLUMN].replace("_", " "); - } - String histologySubtype = null; - if (!EtlCommons.isMissing(fields[HISTOLOGY_SUBTYPE_COLUMN])) { - histologySubtype = fields[HISTOLOGY_SUBTYPE_COLUMN].replace("_", " "); - } - String tumourOrigin = null; - if (!EtlCommons.isMissing(fields[TUMOUR_ORIGIN_COLUMN])) { - tumourOrigin = fields[TUMOUR_ORIGIN_COLUMN].replace("_", " "); - } - String sampleSource = null; - if (!EtlCommons.isMissing(fields[SAMPLE_SOURCE_COLUMN])) { - sampleSource = fields[SAMPLE_SOURCE_COLUMN].replace("_", " "); - } - - return new SomaticInformation(primarySite, siteSubtype, primaryHistology, histologySubtype, tumourOrigin, sampleSource); - } - - private List getBibliography(String bibliographyString) { - if (!EtlCommons.isMissing(bibliographyString)) { - return Collections.singletonList("PMID:" + bibliographyString); - } - - return Collections.emptyList(); - } - - private List getGenomicFeature(String[] fields) { - List genomicFeatureList = new ArrayList<>(5); - if (fields[GENE_NAMES_COLUMN].contains("_")) { - genomicFeatureList.add(createGeneGenomicFeature(fields[GENE_NAMES_COLUMN].split("_")[0])); - } - // Add transcript ID - if (StringUtils.isNotEmpty(fields[1])) { - genomicFeatureList.add(createGeneGenomicFeature(fields[1], FeatureTypes.transcript)); - } - if (!fields[HGNC_COLUMN].equalsIgnoreCase(fields[GENE_NAMES_COLUMN]) && !EtlCommons.isMissing(fields[HGNC_COLUMN])) { - genomicFeatureList.add(createGeneGenomicFeature(fields[HGNC_COLUMN])); - } - - return genomicFeatureList; - } - - public SequenceLocation parseLocation(String[] fields) { - SequenceLocation sequenceLocation = null; - String locationString = fields[25]; - if (StringUtils.isNotEmpty(locationString)) { - Matcher matcher = mutationGRCh37GenomePositionPattern.matcher(locationString); - if (matcher.matches()) { - sequenceLocation = new SequenceLocation(); - sequenceLocation.setChromosome(getCosmicChromosome(matcher.group(CHROMOSOME))); - sequenceLocation.setStrand(fields[26]); - - String mutationCds = fields[HGVS_COLUMN]; - VariantType variantType = getVariantType(mutationCds); - if (VariantType.INSERTION.equals(variantType)) { - sequenceLocation.setEnd(Integer.parseInt(matcher.group(START))); - sequenceLocation.setStart(Integer.parseInt(matcher.group(END))); - } else { - sequenceLocation.setStart(Integer.parseInt(matcher.group(START))); - sequenceLocation.setEnd(Integer.parseInt(matcher.group(END))); - } - } + logger.info("Parsing cosmic file ..."); + CosmicIndexerCallback callback = new CosmicIndexerCallback(rdb, this); + CosmicParser.parse(cosmicFile, COSMIC_VERSION, EtlCommons.COSMIC_DATA, assembly, callback); + } catch (IOException | FileFormatException e) { + throw new CellBaseException("Error parsing COSMIC file " + cosmicFile, e); } - if (sequenceLocation == null) { - this.invalidPositionLines++; - } - return sequenceLocation; } - - private String getCosmicChromosome(String chromosome) { - switch (chromosome) { - case "23": - return "X"; - case "24": - return "Y"; - case "25": - return "MT"; - default: - return chromosome; - } - } - } diff --git a/cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/CosmicIndexerCallback.java b/cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/CosmicIndexerCallback.java new file mode 100644 index 0000000000..cde227308d --- /dev/null +++ b/cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/CosmicIndexerCallback.java @@ -0,0 +1,266 @@ +/* + * Copyright 2015-2020 OpenCB + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package org.opencb.cellbase.lib.builders.clinical.variant; + +import org.apache.commons.lang3.StringUtils; +import org.opencb.biodata.formats.variant.cosmic.CosmicParserCallback; +import org.opencb.biodata.models.sequence.SequenceLocation; +import org.opencb.biodata.models.variant.avro.*; +import org.rocksdb.RocksDB; +import org.rocksdb.RocksDBException; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +import java.io.IOException; +import java.util.ArrayList; +import java.util.HashSet; +import java.util.List; +import java.util.Set; +import java.util.regex.Matcher; +import java.util.regex.Pattern; + +public class CosmicIndexerCallback implements CosmicParserCallback { + + private RocksDB rdb; + private ClinicalIndexer clinicalIndexer; + + private static final int GENE_NAMES_COLUMN = 0; + private static final int HGNC_COLUMN = 3; + private static final int PRIMARY_SITE_COLUMN = 7; + private static final int SITE_SUBTYPE_COLUMN = 8; + private static final int PRIMARY_HISTOLOGY_COLUMN = 11; + private static final int HISTOLOGY_SUBTYPE_COLUMN = 12; + private static final int ID_COLUMN = 16; + private static final int COSM_ID_COLUMN = 17; + private static final int HGVS_COLUMN = 19; + private static final int MUTATION_DESCRIPTION_COLUMN = 21; + private static final int MUTATION_ZYGOSITY_COLUMN = 22; + private static final int FATHMM_PREDICTION_COLUMN = 29; + private static final int FATHMM_SCORE_COLUMN = 30; + private static final int MUTATION_SOMATIC_STATUS_COLUMN = 31; + private static final int PUBMED_PMID_COLUMN = 32; + private static final int SAMPLE_SOURCE_COLUMN = 34; + private static final int TUMOUR_ORIGIN_COLUMN = 35; + + private static final String HGVS_INSERTION_TAG = "ins"; + private static final String HGVS_SNV_CHANGE_SYMBOL = ">"; + private static final String HGVS_DELETION_TAG = "del"; + private static final String HGVS_DUPLICATION_TAG = "dup"; + private static final String CHROMOSOME = "CHR"; + private static final String START = "START"; + private static final String END = "END"; + private static final String REF = "REF"; + private static final String ALT = "ALT"; + private int invalidPositionLines = 0; + private int invalidSubstitutionLines = 0; + private int invalidDeletionLines = 0; + private int invalidInsertionLines = 0; + private int invalidDuplicationLines = 0; + private int invalidMutationCDSOtherReason = 0; + + private Pattern mutationGRCh37GenomePositionPattern = Pattern.compile("(?<" + CHROMOSOME + ">\\S+):(?<" + START + ">\\d+)-(?<" + + END + ">\\d+)"); + private Pattern snvPattern = Pattern.compile("c\\.\\d+((\\+|\\-|_)\\d+)?(?<" + REF + ">(A|C|T|G)+)>(?<" + ALT + ">(A|C|T|G)+)"); + + private static Logger logger = LoggerFactory.getLogger(CosmicIndexerCallback.class); + + public CosmicIndexerCallback(RocksDB rdb, ClinicalIndexer clinicalIndexer) { + this.rdb = rdb; + this.clinicalIndexer = clinicalIndexer; + } + + @Override + public boolean processEvidenceEntries(SequenceLocation sequenceLocation, List evidenceEntries) { + try { + return updateRocksDB(sequenceLocation, evidenceEntries); + } catch (Exception e) { + return false; + } + } + + private boolean updateRocksDB(SequenceLocation sequenceLocation, List evidenceEntries) + throws RocksDBException, IOException { + // More than one variant being returned from the normalisation process would mean it's and MNV which has been decomposed + List normalisedVariantStringList = clinicalIndexer.getNormalisedVariantString(sequenceLocation.getChromosome(), + sequenceLocation.getStart(), sequenceLocation.getReference(), sequenceLocation.getAlternate()); + if (normalisedVariantStringList != null) { + for (String normalisedVariantString : normalisedVariantStringList) { + VariantAnnotation variantAnnotation = clinicalIndexer.getVariantAnnotation(normalisedVariantString.getBytes()); + List mergedEvidenceEntries = mergeEvidenceEntries(evidenceEntries); + clinicalIndexer.addHaplotypeProperty(mergedEvidenceEntries, normalisedVariantStringList); + // IMPORTANT: COSMIC must be indexed first because of the next line !!! + variantAnnotation.setTraitAssociation(mergedEvidenceEntries); + rdb.put(normalisedVariantString.getBytes(), clinicalIndexer.jsonObjectWriter.writeValueAsBytes(variantAnnotation)); + } + return true; + } + return false; + } + + private List mergeEvidenceEntries(List evidenceEntries) { + List mergedEvidenceEntries = new ArrayList<>(); + if (evidenceEntries.size() > 0) { + mergedEvidenceEntries.add(evidenceEntries.get(0)); + // For each evidence entry ... + for (int i = 1; i < evidenceEntries.size(); i++) { + boolean merged = false; + // ... check if it matches a existing evidence entry + for (EvidenceEntry mergedEvidenceEntry : mergedEvidenceEntries) { + if (sameSomaticDocument(evidenceEntries.get(i), mergedEvidenceEntry)) { + // Merge Transcripts + if (mergedEvidenceEntry.getGenomicFeatures() != null) { + if (evidenceEntries.get(i).getGenomicFeatures() != null) { + for (GenomicFeature newGenomicFeature : evidenceEntries.get(i).getGenomicFeatures()) { + if (newGenomicFeature.getFeatureType().equals(FeatureTypes.transcript)) { + boolean found = false; + for (GenomicFeature feature : mergedEvidenceEntry.getGenomicFeatures()) { + if (feature.getXrefs().get(clinicalIndexer.SYMBOL) + .equals(newGenomicFeature.getXrefs().get(clinicalIndexer.SYMBOL))) { + found = true; + } + } + if (!found) { + mergedEvidenceEntry.getGenomicFeatures().add(newGenomicFeature); + } + } + } + } + } else { + mergedEvidenceEntry.setGenomicFeatures(evidenceEntries.get(i).getGenomicFeatures()); + } + + // Merge Bibliography + // There are cosmic records which share all the fields but the bibliography. In some occassions (COSM12600) + // the redundancy is such that the document becomes much bigger than 16MB and cannot be loaded into MongoDB. + // This merge reduces redundancy. + if (mergedEvidenceEntry.getBibliography() != null) { + if (evidenceEntries.get(i).getBibliography() != null) { + Set bibliographySet = new HashSet<>(mergedEvidenceEntry.getBibliography()); + bibliographySet.addAll(new HashSet<>(evidenceEntries.get(i).getBibliography())); + mergedEvidenceEntry.setBibliography(new ArrayList<>(bibliographySet)); + } + } else { + mergedEvidenceEntry.setBibliography(evidenceEntries.get(i).getBibliography()); + } + + merged = true; + break; + } + } + if (!merged) { + mergedEvidenceEntries.add(evidenceEntries.get(i)); + } + } + } + + return mergedEvidenceEntries; + } + + public boolean sameSomaticDocument(EvidenceEntry evidenceEntry1, EvidenceEntry evidenceEntry2) { + if (evidenceEntry1 == evidenceEntry2) { + return true; + } + if (evidenceEntry2 == null || evidenceEntry1.getClass() != evidenceEntry2.getClass()) { + return false; + } + + if (evidenceEntry1.getSource() != null ? !evidenceEntry1.getSource().equals(evidenceEntry2.getSource()) + : evidenceEntry2.getSource() != null) { + return false; + } + if (evidenceEntry1.getSomaticInformation() != null + ? !evidenceEntry1.getSomaticInformation().equals(evidenceEntry2.getSomaticInformation()) + : evidenceEntry2.getSomaticInformation() != null) { + return false; + } + if (evidenceEntry1.getId() != null + ? !evidenceEntry1.getId().equals(evidenceEntry2.getId()) : evidenceEntry2.getId() != null) { + return false; + } + if (evidenceEntry1.getAlleleOrigin() != null + ? !evidenceEntry1.getAlleleOrigin().equals(evidenceEntry2.getAlleleOrigin()) + : evidenceEntry2.getAlleleOrigin() != null) { + return false; + } + if (evidenceEntry1.getGenomicFeatures() != null + ? !evidenceEntry1.getGenomicFeatures().equals(evidenceEntry2.getGenomicFeatures()) + : evidenceEntry2.getGenomicFeatures() != null) { + return false; + } + if (evidenceEntry1.getAdditionalProperties() != null + ? !evidenceEntry1.getAdditionalProperties().equals(evidenceEntry2.getAdditionalProperties()) + : evidenceEntry2.getAdditionalProperties() != null) { + return false; + } + + return true; + } + + private VariantType getVariantType(String mutationCds) { + if (mutationCds.contains(HGVS_SNV_CHANGE_SYMBOL)) { + return VariantType.SNV; + } else if (mutationCds.contains(HGVS_DELETION_TAG)) { + return VariantType.DELETION; + } else if (mutationCds.contains(HGVS_INSERTION_TAG)) { + return VariantType.INSERTION; + } else if (mutationCds.contains(HGVS_DUPLICATION_TAG)) { + return VariantType.DUPLICATION; + } else { + return null; + } + } + + public SequenceLocation parseLocation(String[] fields) { + SequenceLocation sequenceLocation = null; + String locationString = fields[25]; + if (StringUtils.isNotEmpty(locationString)) { + Matcher matcher = mutationGRCh37GenomePositionPattern.matcher(locationString); + if (matcher.matches()) { + sequenceLocation = new SequenceLocation(); + sequenceLocation.setChromosome(getCosmicChromosome(matcher.group(CHROMOSOME))); + sequenceLocation.setStrand(fields[26]); + + String mutationCds = fields[HGVS_COLUMN]; + VariantType variantType = getVariantType(mutationCds); + if (VariantType.INSERTION.equals(variantType)) { + sequenceLocation.setEnd(Integer.parseInt(matcher.group(START))); + sequenceLocation.setStart(Integer.parseInt(matcher.group(END))); + } else { + sequenceLocation.setStart(Integer.parseInt(matcher.group(START))); + sequenceLocation.setEnd(Integer.parseInt(matcher.group(END))); + } + } + } + if (sequenceLocation == null) { + this.invalidPositionLines++; + } + return sequenceLocation; + } + + private String getCosmicChromosome(String chromosome) { + switch (chromosome) { + case "23": + return "X"; + case "24": + return "Y"; + case "25": + return "MT"; + default: + return chromosome; + } + } +} From fff65d11aca3880e6f4746d40f7c868b2e05326f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Joaqu=C3=ADn=20T=C3=A1rraga=20Gim=C3=A9nez?= Date: Wed, 26 Jun 2024 16:22:49 +0200 Subject: [PATCH 03/19] lib: remove the SequenceLocation class to use it from the package biodata, #TASK-6427, #TASK-5318 On branch TASK-5318 Changes to be committed: modified: cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/ClinVarIndexer.java modified: cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/ClinicalIndexer.java modified: cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/ClinicalVariantBuilder.java modified: cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/IARCTP53Indexer.java --- .../clinical/variant/ClinVarIndexer.java | 1 + .../clinical/variant/ClinicalIndexer.java | 88 ------------------- .../variant/ClinicalVariantBuilder.java | 3 +- .../clinical/variant/IARCTP53Indexer.java | 1 + 4 files changed, 4 insertions(+), 89 deletions(-) diff --git a/cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/ClinVarIndexer.java b/cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/ClinVarIndexer.java index a31bd8d5e6..1817359e98 100644 --- a/cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/ClinVarIndexer.java +++ b/cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/ClinVarIndexer.java @@ -20,6 +20,7 @@ import org.apache.commons.lang3.StringUtils; import org.opencb.biodata.formats.variant.clinvar.rcv.ClinvarParser; import org.opencb.biodata.formats.variant.clinvar.rcv.v64jaxb.*; +import org.opencb.biodata.models.sequence.SequenceLocation; import org.opencb.biodata.models.variant.avro.*; import org.opencb.cellbase.lib.EtlCommons; import org.opencb.cellbase.lib.variant.VariantAnnotationUtils; diff --git a/cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/ClinicalIndexer.java b/cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/ClinicalIndexer.java index bbe33017fd..58f04a142d 100644 --- a/cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/ClinicalIndexer.java +++ b/cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/ClinicalIndexer.java @@ -231,92 +231,4 @@ protected void addHaplotypeProperty(List evidenceEntryList, List< } } } - - class SequenceLocation { - private String chromosome; - private int start; - private int end; - private String reference; - private String alternate; - private String strand; - - SequenceLocation() { - } - - SequenceLocation(String chromosome, int start, int end, String reference, String alternate) { - this(chromosome, start, end, reference, alternate, "+"); - } - - SequenceLocation(String chromosome, int start, int end, String reference, String alternate, String strand) { - this.chromosome = chromosome; - this.start = start; - this.end = end; - this.reference = reference; - this.alternate = alternate; - this.strand = strand; - } - - @Override - public String toString() { - final StringBuilder sb = new StringBuilder("SequenceLocation{"); - sb.append("chromosome='").append(chromosome).append('\''); - sb.append(", start=").append(start); - sb.append(", end=").append(end); - sb.append(", reference='").append(reference).append('\''); - sb.append(", alternate='").append(alternate).append('\''); - sb.append(", strand='").append(strand).append('\''); - sb.append('}'); - return sb.toString(); - } - - public String getChromosome() { - return chromosome; - } - - public int getStart() { - return start; - } - - public int getEnd() { - return end; - } - - public String getReference() { - return reference; - } - - public String getAlternate() { - return alternate; - } - - public String getStrand() { - return strand; - } - - public void setChromosome(String chromosome) { - this.chromosome = chromosome; - } - - public void setStart(int start) { - this.start = start; - } - - public void setEnd(int end) { - this.end = end; - } - - public void setReference(String reference) { - this.reference = reference; - } - - public void setAlternate(String alternate) { - this.alternate = alternate; - } - - public void setStrand(String strand) { - this.strand = strand; - } - } - - } diff --git a/cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/ClinicalVariantBuilder.java b/cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/ClinicalVariantBuilder.java index f574133ad7..b1e758ab79 100644 --- a/cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/ClinicalVariantBuilder.java +++ b/cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/ClinicalVariantBuilder.java @@ -19,6 +19,7 @@ import com.fasterxml.jackson.databind.ObjectMapper; import org.opencb.biodata.models.variant.Variant; import org.opencb.biodata.models.variant.avro.VariantAnnotation; +import org.opencb.cellbase.core.exception.CellBaseException; import org.opencb.cellbase.core.serializer.CellBaseSerializer; import org.opencb.cellbase.lib.EtlCommons; import org.opencb.cellbase.lib.builders.CellBaseBuilder; @@ -99,7 +100,7 @@ public ClinicalVariantBuilder(Path clinvarXMLFile, Path clinvarSummaryFile, Path this.assembly = assembly; } - public void parse() throws IOException, RocksDBException { + public void parse() throws IOException, RocksDBException, CellBaseException { RocksDB rdb = null; Options dbOption = null; diff --git a/cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/IARCTP53Indexer.java b/cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/IARCTP53Indexer.java index 930877ed1c..faf8432dee 100644 --- a/cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/IARCTP53Indexer.java +++ b/cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/IARCTP53Indexer.java @@ -16,6 +16,7 @@ package org.opencb.cellbase.lib.builders.clinical.variant; +import org.opencb.biodata.models.sequence.SequenceLocation; import org.opencb.biodata.models.variant.avro.*; import org.opencb.biodata.tools.sequence.FastaIndexManager; import org.opencb.cellbase.lib.EtlCommons; From 78662d6610aaaa06c3e6350a474913345b6c9893 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Joaqu=C3=ADn=20T=C3=A1rraga=20Gim=C3=A9nez?= Date: Fri, 28 Jun 2024 08:51:45 +0200 Subject: [PATCH 04/19] lib: use the same normalization parameters as OpenCGA, #TASK-6427, #TASK-5318 On branch TASK-5318 Changes to be committed: modified: cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/ClinicalIndexer.java --- .../lib/builders/clinical/variant/ClinicalIndexer.java | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/ClinicalIndexer.java b/cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/ClinicalIndexer.java index 58f04a142d..17c2879c87 100644 --- a/cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/ClinicalIndexer.java +++ b/cellbase-lib/src/main/java/org/opencb/cellbase/lib/builders/clinical/variant/ClinicalIndexer.java @@ -74,13 +74,12 @@ public abstract class ClinicalIndexer { protected VariantNormalizer normalizer; public ClinicalIndexer(Path genomeSequenceFilePath) throws IOException { - // Forcing decomposition here in all cases - assuming the way CellBase stores clinical variants from here - // onwards will be decomposed and Adaptors will deal with phased/no-phased queries + // Use the same OpenCGA normalization parameters VariantNormalizer.VariantNormalizerConfig variantNormalizerConfig = (new VariantNormalizer.VariantNormalizerConfig()) .setReuseVariants(true) - .setNormalizeAlleles(false) - .setDecomposeMNVs(true); + .setNormalizeAlleles(true) + .setDecomposeMNVs(false); if (genomeSequenceFilePath != null) { logger.info("Enabling left aligning by using sequence at {}", genomeSequenceFilePath.toString()); From 7d25933ae5c8ea698585d5ac15cf6ffaed14955f Mon Sep 17 00:00:00 2001 From: JuanfeSanahuja Date: Fri, 13 Sep 2024 13:51:36 +0200 Subject: [PATCH 05/19] Prepare release 6.2.2 --- cellbase-app/pom.xml | 2 +- cellbase-client/pom.xml | 2 +- cellbase-core/pom.xml | 2 +- cellbase-lib/pom.xml | 2 +- cellbase-server/pom.xml | 2 +- pom.xml | 2 +- 6 files changed, 6 insertions(+), 6 deletions(-) diff --git a/cellbase-app/pom.xml b/cellbase-app/pom.xml index df777079c3..4b05d287c1 100644 --- a/cellbase-app/pom.xml +++ b/cellbase-app/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.1 + 6.2.2-SNAPSHOT ../pom.xml diff --git a/cellbase-client/pom.xml b/cellbase-client/pom.xml index 2e9b1262ac..f4ecc84585 100644 --- a/cellbase-client/pom.xml +++ b/cellbase-client/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.1 + 6.2.2-SNAPSHOT ../pom.xml diff --git a/cellbase-core/pom.xml b/cellbase-core/pom.xml index 183634a928..1a35c185cc 100644 --- a/cellbase-core/pom.xml +++ b/cellbase-core/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.1 + 6.2.2-SNAPSHOT ../pom.xml diff --git a/cellbase-lib/pom.xml b/cellbase-lib/pom.xml index 0ccb570c21..c1ed6f6ba6 100644 --- a/cellbase-lib/pom.xml +++ b/cellbase-lib/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.1 + 6.2.2-SNAPSHOT ../pom.xml diff --git a/cellbase-server/pom.xml b/cellbase-server/pom.xml index 96319c7cbf..2bee90c836 100644 --- a/cellbase-server/pom.xml +++ b/cellbase-server/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.1 + 6.2.2-SNAPSHOT ../pom.xml diff --git a/pom.xml b/pom.xml index 6c047d1a2b..f44762ec0b 100644 --- a/pom.xml +++ b/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.1 + 6.2.2-SNAPSHOT pom CellBase project From 44904d16e5c5a759b949976efe4183c2c8dacead Mon Sep 17 00:00:00 2001 From: JuanfeSanahuja Date: Fri, 13 Sep 2024 13:52:52 +0200 Subject: [PATCH 06/19] Prepare release 6.2.1 --- pom.xml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/pom.xml b/pom.xml index 6c047d1a2b..2c9aec8a4f 100644 --- a/pom.xml +++ b/pom.xml @@ -23,8 +23,8 @@ ${project.version} - 5.2.2-SNAPSHOT - 3.2.2-SNAPSHOT + 5.2.1 + 3.2.1 0.1.0 2.11.4 From 6c0a9b90801281f97478bdd5ccdb08c560ed8c04 Mon Sep 17 00:00:00 2001 From: JuanfeSanahuja Date: Fri, 13 Sep 2024 13:55:30 +0200 Subject: [PATCH 07/19] Prepare release 6.2.1 --- pom.xml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/pom.xml b/pom.xml index d44272b052..f44762ec0b 100644 --- a/pom.xml +++ b/pom.xml @@ -23,8 +23,8 @@ ${project.version} - 5.2.1 - 3.2.1 + 5.2.2-SNAPSHOT + 3.2.2-SNAPSHOT 0.1.0 2.11.4 From da046310364f686d03a1b9fe4bdb789ae5c2cd2c Mon Sep 17 00:00:00 2001 From: JuanfeSanahuja Date: Mon, 16 Sep 2024 17:17:10 +0200 Subject: [PATCH 08/19] SDLC: Prepare release 2.3.0 of Xetabase #TASK-6879 --- cellbase-app/pom.xml | 2 +- cellbase-client/pom.xml | 2 +- cellbase-core/pom.xml | 2 +- cellbase-lib/pom.xml | 2 +- cellbase-server/pom.xml | 2 +- pom.xml | 2 +- 6 files changed, 6 insertions(+), 6 deletions(-) diff --git a/cellbase-app/pom.xml b/cellbase-app/pom.xml index 4b05d287c1..aed90e9897 100644 --- a/cellbase-app/pom.xml +++ b/cellbase-app/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.2-SNAPSHOT + 6.3.0-SNAPSHOT ../pom.xml diff --git a/cellbase-client/pom.xml b/cellbase-client/pom.xml index f4ecc84585..7424c21bbb 100644 --- a/cellbase-client/pom.xml +++ b/cellbase-client/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.2-SNAPSHOT + 6.3.0-SNAPSHOT ../pom.xml diff --git a/cellbase-core/pom.xml b/cellbase-core/pom.xml index 1a35c185cc..7c74e13d92 100644 --- a/cellbase-core/pom.xml +++ b/cellbase-core/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.2-SNAPSHOT + 6.3.0-SNAPSHOT ../pom.xml diff --git a/cellbase-lib/pom.xml b/cellbase-lib/pom.xml index c1ed6f6ba6..a181ccf4a9 100644 --- a/cellbase-lib/pom.xml +++ b/cellbase-lib/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.2-SNAPSHOT + 6.3.0-SNAPSHOT ../pom.xml diff --git a/cellbase-server/pom.xml b/cellbase-server/pom.xml index 2bee90c836..fe4509c6fc 100644 --- a/cellbase-server/pom.xml +++ b/cellbase-server/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.2-SNAPSHOT + 6.3.0-SNAPSHOT ../pom.xml diff --git a/pom.xml b/pom.xml index f44762ec0b..1b044e12fb 100644 --- a/pom.xml +++ b/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.2-SNAPSHOT + 6.3.0-SNAPSHOT pom CellBase project From 9d8e015435f2f78740645df630fac3f7ada66403 Mon Sep 17 00:00:00 2001 From: JuanfeSanahuja Date: Tue, 17 Sep 2024 14:57:36 +0200 Subject: [PATCH 09/19] pom:update internal dependencies #TASK-6879 --- pom.xml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/pom.xml b/pom.xml index 1b044e12fb..35498a9a40 100644 --- a/pom.xml +++ b/pom.xml @@ -23,8 +23,8 @@ ${project.version} - 5.2.2-SNAPSHOT - 3.2.2-SNAPSHOT + 5.3.0-SNAPSHOT + 3.3.0-SNAPSHOT 0.1.0 2.11.4 From 50a84765888b3691c8eb751bff8681a132eefd5c Mon Sep 17 00:00:00 2001 From: JuanfeSanahuja Date: Tue, 17 Sep 2024 15:10:19 +0200 Subject: [PATCH 10/19] cicd scripts fix new branch and version references #TASK-6879 --- .github/workflows/scripts/get-xetabase-branch.sh | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/scripts/get-xetabase-branch.sh b/.github/workflows/scripts/get-xetabase-branch.sh index 16ae8c4711..fd9626a79a 100644 --- a/.github/workflows/scripts/get-xetabase-branch.sh +++ b/.github/workflows/scripts/get-xetabase-branch.sh @@ -19,11 +19,11 @@ get_xetabase_branch() { return 0 fi - # Check if the branch name starts with "release-" and follows the patterns "release-a.b.x" or "release-a.b.c.x" - if [[ "$input_branch" =~ ^release-([0-9]+)\.([0-9]+)\.x$ ]] || [[ "$input_branch" =~ ^release-([0-9]+)\.([0-9]+)\.([0-9]+)\.x$ ]]; then + # Check if the branch name starts with "release-" and follows the patterns "release-a.x.x" or "release-a.b.x" + if [[ "$input_branch" =~ ^release-([0-9]+)\.x\.x$ ]] || [[ "$input_branch" =~ ^release-([0-9]+)\.([0-9]+)\.x$ ]]; then # Extract the MAJOR part of the branch name MAJOR=${BASH_REMATCH[1]} - # Calculate the XETABASE_MAJOR by subtracting 3 from MAJOR + # Calculate the XETABASE_MAJOR by subtracting 4 from MAJOR of cellbase XETABASE_MAJOR=$((MAJOR - 4)) # Check if the XETABASE_MAJOR is negative if (( XETABASE_MAJOR < 0 )); then From 6a12f4c562b62c7749b4edf25af20a06d9ecd6e2 Mon Sep 17 00:00:00 2001 From: JuanfeSanahuja Date: Tue, 17 Sep 2024 15:13:21 +0200 Subject: [PATCH 11/19] cicd scripts fix new branch and version references #TASK-6879 --- .github/workflows/pull-request-approved.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/pull-request-approved.yml b/.github/workflows/pull-request-approved.yml index d339f65b96..ba378d3abb 100644 --- a/.github/workflows/pull-request-approved.yml +++ b/.github/workflows/pull-request-approved.yml @@ -24,7 +24,7 @@ jobs: chmod +x ./.github/workflows/scripts/get-xetabase-branch.sh echo "github.event.pull_request.base.ref: ${{ github.event.pull_request.base.ref }}" echo "github.event.pull_request.head.ref: ${{ github.event.pull_request.head.ref }}" - xetabase_branch=$(./.github/workflows/scripts/get-xetabase-branch.sh ${{ github.event.pull_request.head.ref }}) + xetabase_branch=$(./.github/workflows/scripts/get-xetabase-branch.sh ${{ github.event.pull_request.base.ref }}) echo "__Xetabase ref:__ \"${xetabase_branch}\"" | tee -a ${GITHUB_STEP_SUMMARY} echo "xetabase_branch=${xetabase_branch}" >> $GITHUB_OUTPUT env: From 050b14e6f4e24a57293de888654c109ee4d42314 Mon Sep 17 00:00:00 2001 From: JuanfeSanahuja Date: Thu, 26 Sep 2024 21:23:51 +0200 Subject: [PATCH 12/19] Prepare release in hotfix branch release-5.2.x --- cellbase-app/pom.xml | 2 +- cellbase-client/pom.xml | 2 +- cellbase-core/pom.xml | 2 +- cellbase-lib/pom.xml | 2 +- cellbase-server/pom.xml | 2 +- pom.xml | 2 +- 6 files changed, 6 insertions(+), 6 deletions(-) diff --git a/cellbase-app/pom.xml b/cellbase-app/pom.xml index df777079c3..4b05d287c1 100644 --- a/cellbase-app/pom.xml +++ b/cellbase-app/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.1 + 6.2.2-SNAPSHOT ../pom.xml diff --git a/cellbase-client/pom.xml b/cellbase-client/pom.xml index 2e9b1262ac..f4ecc84585 100644 --- a/cellbase-client/pom.xml +++ b/cellbase-client/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.1 + 6.2.2-SNAPSHOT ../pom.xml diff --git a/cellbase-core/pom.xml b/cellbase-core/pom.xml index 183634a928..1a35c185cc 100644 --- a/cellbase-core/pom.xml +++ b/cellbase-core/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.1 + 6.2.2-SNAPSHOT ../pom.xml diff --git a/cellbase-lib/pom.xml b/cellbase-lib/pom.xml index 0ccb570c21..c1ed6f6ba6 100644 --- a/cellbase-lib/pom.xml +++ b/cellbase-lib/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.1 + 6.2.2-SNAPSHOT ../pom.xml diff --git a/cellbase-server/pom.xml b/cellbase-server/pom.xml index 96319c7cbf..2bee90c836 100644 --- a/cellbase-server/pom.xml +++ b/cellbase-server/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.1 + 6.2.2-SNAPSHOT ../pom.xml diff --git a/pom.xml b/pom.xml index 6c047d1a2b..f44762ec0b 100644 --- a/pom.xml +++ b/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.1 + 6.2.2-SNAPSHOT pom CellBase project From 737568dcc29ac54245df972a7dd0ffd6e2517667 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Joaqu=C3=ADn=20T=C3=A1rraga=20Gim=C3=A9nez?= Date: Tue, 1 Oct 2024 11:42:24 +0200 Subject: [PATCH 13/19] core: fix configuration file by resolving conflics messages, #TASK-7030 --- cellbase-core/src/main/resources/configuration.yml | 13 ------------- 1 file changed, 13 deletions(-) diff --git a/cellbase-core/src/main/resources/configuration.yml b/cellbase-core/src/main/resources/configuration.yml index 6e651f00d3..84378507b4 100644 --- a/cellbase-core/src/main/resources/configuration.yml +++ b/cellbase-core/src/main/resources/configuration.yml @@ -106,13 +106,6 @@ download: clinvar: # host: https://ftp.ncbi.nlm.nih.gov/pub/clinvar/xml/ClinVarFullRelease_2021-07.xml.gz # host: https://ftp.ncbi.nlm.nih.gov/pub/clinvar/xml/ClinVarFullRelease_2022-02.xml.gz -<<<<<<< HEAD - host: https://ftp.ncbi.nlm.nih.gov/pub/clinvar/xml/ClinVarFullRelease_2022-11.xml.gz - clinvarVariation: -# host: https://ftp.ncbi.nlm.nih.gov/pub/clinvar/xml/clinvar_variation/ClinVarVariationRelease_2021-07.xml.gz -# host: https://ftp.ncbi.nlm.nih.gov/pub/clinvar/xml/clinvar_variation/ClinVarVariationRelease_2022-02.xml.gz - host: https://ftp.ncbi.nlm.nih.gov/pub/clinvar/xml/clinvar_variation/ClinVarVariationRelease_2022-11.xml.gz -======= # host: https://ftp.ncbi.nlm.nih.gov/pub/clinvar/xml/ClinVarFullRelease_2022-11.xml.gz host: https://ftp.ncbi.nlm.nih.gov/pub/clinvar/xml/RCV_xml_old_format/ClinVarFullRelease_2024-05.xml.gz version: 2024-05 @@ -122,7 +115,6 @@ download: # host: https://ftp.ncbi.nlm.nih.gov/pub/clinvar/xml/clinvar_variation/ClinVarVariationRelease_2022-11.xml.gz host: https://ftp.ncbi.nlm.nih.gov/pub/clinvar/xml/VCV_xml_old_format/ClinVarVariationRelease_2024-05.xml.gz version: 2024-05 ->>>>>>> release-6.2.x clinvarSummary: host: http://ftp.ncbi.nlm.nih.gov/pub/clinvar/tab_delimited/variant_summary.txt.gz clinvarVariationAllele: @@ -147,15 +139,10 @@ download: genomicSuperDups: host: http://hgdownload.cse.ucsc.edu/goldenPath gwasCatalog: -<<<<<<< HEAD - host: http://resources.opencb.org/opencb/cellbase/data/gwas/gwas_catalog_v1.0.2-associations_e106_r2022-05-17.tsv - version: "1.0.2 associations_e106_r2022-05-17" -======= #host: http://resources.opencb.org/opencb/cellbase/data/gwas/gwas_catalog_v1.0.2-associations_e106_r2022-05-17.tsv host: "https://ftp.ebi.ac.uk/pub/databases/gwas/releases/2024/05/20/gwas-catalog-associations_ontology-annotated.tsv" #version: "1.0.2 associations_e106_r2022-05-17" version: "2024-05-20" ->>>>>>> release-6.2.x hpo: host: https://ci.monarchinitiative.org/view/hpo/job/hpo.annotations/lastSuccessfulBuild/artifact/rare-diseases/util/annotation/phenotype_to_genes.txt disgenet: From 836965e02a1e888791b810f8d50025e7ba8a02f8 Mon Sep 17 00:00:00 2001 From: JuanfeSanahuja Date: Tue, 1 Oct 2024 12:00:39 +0200 Subject: [PATCH 14/19] cicd: Adapt pull-request-approve workflow to the new SDLC --- .github/workflows/pull-request-approved.yml | 2 +- .github/workflows/scripts/get-xetabase-branch.sh | 6 +++--- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/.github/workflows/pull-request-approved.yml b/.github/workflows/pull-request-approved.yml index d339f65b96..ba378d3abb 100644 --- a/.github/workflows/pull-request-approved.yml +++ b/.github/workflows/pull-request-approved.yml @@ -24,7 +24,7 @@ jobs: chmod +x ./.github/workflows/scripts/get-xetabase-branch.sh echo "github.event.pull_request.base.ref: ${{ github.event.pull_request.base.ref }}" echo "github.event.pull_request.head.ref: ${{ github.event.pull_request.head.ref }}" - xetabase_branch=$(./.github/workflows/scripts/get-xetabase-branch.sh ${{ github.event.pull_request.head.ref }}) + xetabase_branch=$(./.github/workflows/scripts/get-xetabase-branch.sh ${{ github.event.pull_request.base.ref }}) echo "__Xetabase ref:__ \"${xetabase_branch}\"" | tee -a ${GITHUB_STEP_SUMMARY} echo "xetabase_branch=${xetabase_branch}" >> $GITHUB_OUTPUT env: diff --git a/.github/workflows/scripts/get-xetabase-branch.sh b/.github/workflows/scripts/get-xetabase-branch.sh index 16ae8c4711..fd9626a79a 100644 --- a/.github/workflows/scripts/get-xetabase-branch.sh +++ b/.github/workflows/scripts/get-xetabase-branch.sh @@ -19,11 +19,11 @@ get_xetabase_branch() { return 0 fi - # Check if the branch name starts with "release-" and follows the patterns "release-a.b.x" or "release-a.b.c.x" - if [[ "$input_branch" =~ ^release-([0-9]+)\.([0-9]+)\.x$ ]] || [[ "$input_branch" =~ ^release-([0-9]+)\.([0-9]+)\.([0-9]+)\.x$ ]]; then + # Check if the branch name starts with "release-" and follows the patterns "release-a.x.x" or "release-a.b.x" + if [[ "$input_branch" =~ ^release-([0-9]+)\.x\.x$ ]] || [[ "$input_branch" =~ ^release-([0-9]+)\.([0-9]+)\.x$ ]]; then # Extract the MAJOR part of the branch name MAJOR=${BASH_REMATCH[1]} - # Calculate the XETABASE_MAJOR by subtracting 3 from MAJOR + # Calculate the XETABASE_MAJOR by subtracting 4 from MAJOR of cellbase XETABASE_MAJOR=$((MAJOR - 4)) # Check if the XETABASE_MAJOR is negative if (( XETABASE_MAJOR < 0 )); then From 15efe18c2a3578458cb3536e7e1dd076573a44aa Mon Sep 17 00:00:00 2001 From: JuanfeSanahuja Date: Tue, 8 Oct 2024 09:21:57 +0200 Subject: [PATCH 15/19] Prepare release 6.2.2 --- cellbase-app/pom.xml | 2 +- cellbase-client/pom.xml | 2 +- cellbase-core/pom.xml | 2 +- cellbase-lib/pom.xml | 2 +- cellbase-server/pom.xml | 2 +- pom.xml | 6 +++--- 6 files changed, 8 insertions(+), 8 deletions(-) diff --git a/cellbase-app/pom.xml b/cellbase-app/pom.xml index 4b05d287c1..468e4c05d7 100644 --- a/cellbase-app/pom.xml +++ b/cellbase-app/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.2-SNAPSHOT + 6.2.2 ../pom.xml diff --git a/cellbase-client/pom.xml b/cellbase-client/pom.xml index f4ecc84585..b519e5ec30 100644 --- a/cellbase-client/pom.xml +++ b/cellbase-client/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.2-SNAPSHOT + 6.2.2 ../pom.xml diff --git a/cellbase-core/pom.xml b/cellbase-core/pom.xml index 1a35c185cc..e9d96cdbfd 100644 --- a/cellbase-core/pom.xml +++ b/cellbase-core/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.2-SNAPSHOT + 6.2.2 ../pom.xml diff --git a/cellbase-lib/pom.xml b/cellbase-lib/pom.xml index c1ed6f6ba6..7ae048359e 100644 --- a/cellbase-lib/pom.xml +++ b/cellbase-lib/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.2-SNAPSHOT + 6.2.2 ../pom.xml diff --git a/cellbase-server/pom.xml b/cellbase-server/pom.xml index 2bee90c836..a772dc2b0c 100644 --- a/cellbase-server/pom.xml +++ b/cellbase-server/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.2-SNAPSHOT + 6.2.2 ../pom.xml diff --git a/pom.xml b/pom.xml index f44762ec0b..2933457498 100644 --- a/pom.xml +++ b/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.2-SNAPSHOT + 6.2.2 pom CellBase project @@ -23,8 +23,8 @@ ${project.version} - 5.2.2-SNAPSHOT - 3.2.2-SNAPSHOT + 5.2.2 + 3.2.2 0.1.0 2.11.4 From 55dd516bbc9d88cab918fd410a4b35594e1a0300 Mon Sep 17 00:00:00 2001 From: JuanfeSanahuja Date: Tue, 8 Oct 2024 16:39:09 +0200 Subject: [PATCH 16/19] Prepare Port Patch 2.2.2 -> 2.3.0 #TASK-7038 --- cellbase-app/pom.xml | 2 +- cellbase-client/pom.xml | 2 +- cellbase-core/pom.xml | 2 +- cellbase-lib/pom.xml | 2 +- cellbase-server/pom.xml | 2 +- pom.xml | 2 +- 6 files changed, 6 insertions(+), 6 deletions(-) diff --git a/cellbase-app/pom.xml b/cellbase-app/pom.xml index 468e4c05d7..aed90e9897 100644 --- a/cellbase-app/pom.xml +++ b/cellbase-app/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.2 + 6.3.0-SNAPSHOT ../pom.xml diff --git a/cellbase-client/pom.xml b/cellbase-client/pom.xml index b519e5ec30..7424c21bbb 100644 --- a/cellbase-client/pom.xml +++ b/cellbase-client/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.2 + 6.3.0-SNAPSHOT ../pom.xml diff --git a/cellbase-core/pom.xml b/cellbase-core/pom.xml index e9d96cdbfd..7c74e13d92 100644 --- a/cellbase-core/pom.xml +++ b/cellbase-core/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.2 + 6.3.0-SNAPSHOT ../pom.xml diff --git a/cellbase-lib/pom.xml b/cellbase-lib/pom.xml index 7ae048359e..a181ccf4a9 100644 --- a/cellbase-lib/pom.xml +++ b/cellbase-lib/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.2 + 6.3.0-SNAPSHOT ../pom.xml diff --git a/cellbase-server/pom.xml b/cellbase-server/pom.xml index a772dc2b0c..fe4509c6fc 100644 --- a/cellbase-server/pom.xml +++ b/cellbase-server/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.2 + 6.3.0-SNAPSHOT ../pom.xml diff --git a/pom.xml b/pom.xml index c63760959b..72d8a41e02 100644 --- a/pom.xml +++ b/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.2.2 + 6.3.0-SNAPSHOT pom CellBase project From 595a3dd5291a74349595299738d80a251a152a2e Mon Sep 17 00:00:00 2001 From: JuanfeSanahuja Date: Tue, 15 Oct 2024 19:18:25 +0200 Subject: [PATCH 17/19] Prepare release 6.3.0 --- cellbase-app/pom.xml | 2 +- cellbase-client/pom.xml | 2 +- cellbase-core/pom.xml | 2 +- cellbase-lib/pom.xml | 2 +- cellbase-server/pom.xml | 2 +- pom.xml | 6 +++--- 6 files changed, 8 insertions(+), 8 deletions(-) diff --git a/cellbase-app/pom.xml b/cellbase-app/pom.xml index aed90e9897..a66c3db4b0 100644 --- a/cellbase-app/pom.xml +++ b/cellbase-app/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.3.0-SNAPSHOT + 6.3.0 ../pom.xml diff --git a/cellbase-client/pom.xml b/cellbase-client/pom.xml index 7424c21bbb..7fa9cf92fc 100644 --- a/cellbase-client/pom.xml +++ b/cellbase-client/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.3.0-SNAPSHOT + 6.3.0 ../pom.xml diff --git a/cellbase-core/pom.xml b/cellbase-core/pom.xml index 7c74e13d92..08051e82c3 100644 --- a/cellbase-core/pom.xml +++ b/cellbase-core/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.3.0-SNAPSHOT + 6.3.0 ../pom.xml diff --git a/cellbase-lib/pom.xml b/cellbase-lib/pom.xml index a181ccf4a9..10076ad8dd 100644 --- a/cellbase-lib/pom.xml +++ b/cellbase-lib/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.3.0-SNAPSHOT + 6.3.0 ../pom.xml diff --git a/cellbase-server/pom.xml b/cellbase-server/pom.xml index fe4509c6fc..02204b0cc5 100644 --- a/cellbase-server/pom.xml +++ b/cellbase-server/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.3.0-SNAPSHOT + 6.3.0 ../pom.xml diff --git a/pom.xml b/pom.xml index 7717413830..6e035de53b 100644 --- a/pom.xml +++ b/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.3.0-SNAPSHOT + 6.3.0 pom CellBase project @@ -23,8 +23,8 @@ ${project.version} - 5.3.0-SNAPSHOT - 3.3.0-SNAPSHOT + 5.3.0 + 3.3.0 0.1.0 2.11.4 1.9.13 From 27366cf297076674be46aca840a19a8d900682a0 Mon Sep 17 00:00:00 2001 From: JuanfeSanahuja Date: Thu, 17 Oct 2024 10:43:08 +0200 Subject: [PATCH 18/19] Prepare Port Patch 6.3.0 -> 7.0.0 Xetabase 2.3.0 -> 3.0.0 #TASK-7097 --- cellbase-app/pom.xml | 2 +- cellbase-client/pom.xml | 2 +- cellbase-core/pom.xml | 2 +- cellbase-lib/pom.xml | 2 +- cellbase-server/pom.xml | 2 +- pom.xml | 2 +- 6 files changed, 6 insertions(+), 6 deletions(-) diff --git a/cellbase-app/pom.xml b/cellbase-app/pom.xml index a66c3db4b0..a48a872cfc 100644 --- a/cellbase-app/pom.xml +++ b/cellbase-app/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.3.0 + 4.0.0-SNAPSHOT ../pom.xml diff --git a/cellbase-client/pom.xml b/cellbase-client/pom.xml index 7fa9cf92fc..10a99fbbff 100644 --- a/cellbase-client/pom.xml +++ b/cellbase-client/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.3.0 + 4.0.0-SNAPSHOT ../pom.xml diff --git a/cellbase-core/pom.xml b/cellbase-core/pom.xml index 08051e82c3..5dbce2323e 100644 --- a/cellbase-core/pom.xml +++ b/cellbase-core/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.3.0 + 4.0.0-SNAPSHOT ../pom.xml diff --git a/cellbase-lib/pom.xml b/cellbase-lib/pom.xml index 10076ad8dd..0ab2566b4f 100644 --- a/cellbase-lib/pom.xml +++ b/cellbase-lib/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.3.0 + 4.0.0-SNAPSHOT ../pom.xml diff --git a/cellbase-server/pom.xml b/cellbase-server/pom.xml index 02204b0cc5..9494b30f01 100644 --- a/cellbase-server/pom.xml +++ b/cellbase-server/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.3.0 + 4.0.0-SNAPSHOT ../pom.xml diff --git a/pom.xml b/pom.xml index 6e035de53b..b976538c07 100644 --- a/pom.xml +++ b/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 6.3.0 + 4.0.0-SNAPSHOT pom CellBase project From f55ebdacca593e07a89932e13c22b171a9250e5e Mon Sep 17 00:00:00 2001 From: JuanfeSanahuja Date: Thu, 17 Oct 2024 10:49:46 +0200 Subject: [PATCH 19/19] Prepare Port Patch 6.3.0 -> 7.0.0 Xetabase 2.3.0 -> 3.0.0 #TASK-7097 --- cellbase-app/pom.xml | 2 +- cellbase-client/pom.xml | 2 +- cellbase-core/pom.xml | 2 +- cellbase-lib/pom.xml | 2 +- cellbase-server/pom.xml | 2 +- pom.xml | 2 +- 6 files changed, 6 insertions(+), 6 deletions(-) diff --git a/cellbase-app/pom.xml b/cellbase-app/pom.xml index a48a872cfc..2877826403 100644 --- a/cellbase-app/pom.xml +++ b/cellbase-app/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 4.0.0-SNAPSHOT + 7.0.0-SNAPSHOT ../pom.xml diff --git a/cellbase-client/pom.xml b/cellbase-client/pom.xml index 10a99fbbff..9fc6f72f07 100644 --- a/cellbase-client/pom.xml +++ b/cellbase-client/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 4.0.0-SNAPSHOT + 7.0.0-SNAPSHOT ../pom.xml diff --git a/cellbase-core/pom.xml b/cellbase-core/pom.xml index 5dbce2323e..f4659e2759 100644 --- a/cellbase-core/pom.xml +++ b/cellbase-core/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 4.0.0-SNAPSHOT + 7.0.0-SNAPSHOT ../pom.xml diff --git a/cellbase-lib/pom.xml b/cellbase-lib/pom.xml index 0ab2566b4f..514d844894 100644 --- a/cellbase-lib/pom.xml +++ b/cellbase-lib/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 4.0.0-SNAPSHOT + 7.0.0-SNAPSHOT ../pom.xml diff --git a/cellbase-server/pom.xml b/cellbase-server/pom.xml index 9494b30f01..d89aa0e106 100644 --- a/cellbase-server/pom.xml +++ b/cellbase-server/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 4.0.0-SNAPSHOT + 7.0.0-SNAPSHOT ../pom.xml diff --git a/pom.xml b/pom.xml index b976538c07..a48b870395 100644 --- a/pom.xml +++ b/pom.xml @@ -6,7 +6,7 @@ org.opencb.cellbase cellbase - 4.0.0-SNAPSHOT + 7.0.0-SNAPSHOT pom CellBase project