From 6dd2f5cb4af69aaaf34ab3ba045bfa3c31757e5a Mon Sep 17 00:00:00 2001 From: Bryant Austin Date: Mon, 19 Aug 2024 21:21:17 -0600 Subject: [PATCH] Add race and ethnicity bindings to bindings collection (#531) * added extension bindings * added org.reflections to pom * changes for PR --------- Co-authored-by: c-schuler --- tooling/pom.xml | 2 +- ...uctureDefinitionElementBindingVisitor.java | 104 ++++++++++++++++-- .../operation/ProfilesToSpreadsheet.java | 22 ++-- .../QICoreElementsToSpreadsheet.java | 4 +- 4 files changed, 112 insertions(+), 20 deletions(-) diff --git a/tooling/pom.xml b/tooling/pom.xml index f87214997..9fd2039cb 100644 --- a/tooling/pom.xml +++ b/tooling/pom.xml @@ -397,4 +397,4 @@ - \ No newline at end of file + diff --git a/tooling/src/main/java/org/opencds/cqf/tooling/acceleratorkit/StructureDefinitionElementBindingVisitor.java b/tooling/src/main/java/org/opencds/cqf/tooling/acceleratorkit/StructureDefinitionElementBindingVisitor.java index bd2f787dc..0c91f765a 100644 --- a/tooling/src/main/java/org/opencds/cqf/tooling/acceleratorkit/StructureDefinitionElementBindingVisitor.java +++ b/tooling/src/main/java/org/opencds/cqf/tooling/acceleratorkit/StructureDefinitionElementBindingVisitor.java @@ -43,7 +43,8 @@ public Map visitStructureDefinition(St getBindings(sdName, eds, sdURL, sdVersion, bindingObjects); } if (sd.hasBaseDefinition()) { - bindingObjects.putAll(visitStructureDefinition(this.canonicalResourceDependenciesAtlas.getStructureDefinitions().getByCanonicalUrlWithVersion(sd.getBaseDefinition()), snapshotOnly)); } + bindingObjects.putAll(visitStructureDefinition(this.canonicalResourceDependenciesAtlas.getStructureDefinitions().getByCanonicalUrlWithVersion(sd.getBaseDefinition()), snapshotOnly)); + } } return bindingObjects; } @@ -71,7 +72,7 @@ private void getBindings(String sdName, List eds, String sdUR sdbo.setSdURL(sdURL); sdbo.setSdVersion(sdVersion); sdbo.setBindingStrength(ed.getBinding().getStrength().toString().toLowerCase()); - if(ed.hasMin() && ed.hasMax()){ + if (ed.hasMin() && ed.hasMax()) { String edCardinality = ed.getMin() + "..." + ed.getMax(); sdbo.setCardinality(edCardinality); } @@ -97,16 +98,16 @@ private void getBindings(String sdName, List eds, String sdUR valueSetVersion = pipeVersion; } if (null != elementValueSet) { - StringBuilder codeSystemURLs = new StringBuilder();; + StringBuilder codeSystemURLs = new StringBuilder(); Map codeSystemsMap = new HashMap<>(); getValueSetCodeSystems(elementValueSet, codeSystemsMap); - if(null != codeSystemsMap && !codeSystemsMap.isEmpty()) { - AtomicReference valueCount = new AtomicReference<>(0); - codeSystemsMap.values().forEach((url)->{ + if (null != codeSystemsMap && !codeSystemsMap.isEmpty()) { + AtomicReference valueCount = new AtomicReference<>(0); + codeSystemsMap.values().forEach((url) -> { codeSystemURLs.append(url); valueCount.set(valueCount.get() + 1); - if(valueCount.get() > 0 && - valueCount.get() < codeSystemsMap.size()) { + if (valueCount.get() > 0 && + valueCount.get() < codeSystemsMap.size()) { codeSystemURLs.append(";"); } }); @@ -121,15 +122,100 @@ private void getBindings(String sdName, List eds, String sdUR sdbo.setBindingValueSetVersion(valueSetVersion); bindingObjects.put(sdName + "." + sdbo.getElementId(), sdbo); } + else if (ed.hasExtension()) { + visitExtensions(ed, bindingObjects, sdName, sdURL, sdVersion); + } index.set(index.get() + 1); } } + private void visitExtensions(ElementDefinition ed, Map bindingObjects, String sdName, String sdURL, String sdVersion) { + StructureDefinitionBindingObject sdbo = new StructureDefinitionBindingObject(); + sdbo.setSdName(sdName); + sdbo.setSdURL(sdURL); + sdbo.setSdVersion(sdVersion); + sdbo.setElementId(ed.getId()); + if (ed.getMustSupport()) { + sdbo.setMustSupport("Y"); + } else { + sdbo.setMustSupport("N"); + } + if (ed.hasMin()) { + String edCardinality = ed.getMin() + "..." + ed.getMax(); + sdbo.setCardinality(edCardinality); + } + CanonicalType canonicalType = new CanonicalType(); + Iterable sdList = null; + try { + if (ed.getType().get(0).getProfile().size() != 0) { + canonicalType.setValue(String.valueOf(ed.getType().get(0).getProfile().get(0))); + sdList = this.canonicalResourceDependenciesAtlas.getStructureDefinitions().getByCanonicalUrl(ed.getType().get(0).getProfile().get(0).getValueAsString()); + } else if (ed.getType().get(0).getTargetProfile().size() != 0) { + canonicalType.setValue(String.valueOf(ed.getType().get(0).getTargetProfile())); + sdList = this.canonicalResourceDependenciesAtlas.getStructureDefinitions().getByCanonicalUrl(ed.getType().get(0).getTargetProfile().get(0).getValueAsString()); + } + else{ + return; + } + } catch (Exception ex) { + return; + } + if (sdList != null) { + sdList.forEach((structDef) -> { + List edsds = structDef.getDifferential().getElement(); + edsds.forEach(edsd -> { + if (edsd.hasBinding()) { + sdbo.setBindingStrength(edsd.getBinding().getStrength().toString().toLowerCase()); + String bindingValueSet = edsd.getBinding().getValueSet(); + String pipeVersion = ""; + if (bindingValueSet.contains("|")) { + pipeVersion = bindingValueSet.substring(bindingValueSet.indexOf("|") + 1); + bindingValueSet = bindingValueSet.substring(0, bindingValueSet.indexOf("|")); + } + sdbo.setBindingValueSetURL(bindingValueSet); + String valueSetVersion = ""; + ValueSet elementValueSet = null; + if (null != this.canonicalResourceAtlas.getValueSets().getByCanonicalUrlWithVersion(sdbo.getBindingValueSetURL())) { + valueSetVersion = this.canonicalResourceAtlas.getValueSets().getByCanonicalUrlWithVersion(sdbo.getBindingValueSetURL()).getVersion(); + sdbo.setBindingValueSetName(this.canonicalResourceAtlas.getValueSets().getByCanonicalUrlWithVersion(sdbo.getBindingValueSetURL()).getName()); + elementValueSet = this.canonicalResourceAtlas.getValueSets().getByCanonicalUrlWithVersion(sdbo.getBindingValueSetURL()); + } else if (null != this.canonicalResourceDependenciesAtlas.getValueSets().getByCanonicalUrlWithVersion(sdbo.getBindingValueSetURL())) { + valueSetVersion = this.canonicalResourceDependenciesAtlas.getValueSets().getByCanonicalUrlWithVersion(sdbo.getBindingValueSetURL()).getVersion(); + sdbo.setBindingValueSetName(this.canonicalResourceDependenciesAtlas.getValueSets().getByCanonicalUrlWithVersion(sdbo.getBindingValueSetURL()).getName()); + elementValueSet = this.canonicalResourceDependenciesAtlas.getValueSets().getByCanonicalUrlWithVersion(sdbo.getBindingValueSetURL()); + } else if (valueSetVersion.isEmpty() && bindingValueSet.contains("|")) { + valueSetVersion = pipeVersion; + } + sdbo.setBindingValueSetVersion(valueSetVersion); + if (null != elementValueSet) { + StringBuilder codeSystemURLs = new StringBuilder(); + Map codeSystemsMap = new HashMap<>(); + getValueSetCodeSystems(elementValueSet, codeSystemsMap); + if (!codeSystemsMap.isEmpty()) { + AtomicReference valueCount = new AtomicReference<>(0); + codeSystemsMap.values().forEach((url) -> { + codeSystemURLs.append(url); + valueCount.set(valueCount.get() + 1); + if (valueCount.get() > 0 && + valueCount.get() < codeSystemsMap.size()) { + codeSystemURLs.append(";"); + } + }); + sdbo.setCodeSystemsURLs(codeSystemURLs.toString()); + } + } + } + }); + }); + } + bindingObjects.put(sdName + "." + sdbo.getElementId(), sdbo); + } + private void getValueSetCodeSystems(ValueSet elementValueSet, Map codeSystemsMap) { ValueSet.ValueSetComposeComponent compose = elementValueSet.getCompose(); if (null != compose) { for (ValueSet.ConceptSetComponent include : compose.getInclude()) { - if(include.hasSystem()){ + if (include.hasSystem()) { codeSystemsMap.put(include.getSystem(), include.getSystem()); } for (CanonicalType r : include.getValueSet()) { diff --git a/tooling/src/main/java/org/opencds/cqf/tooling/operation/ProfilesToSpreadsheet.java b/tooling/src/main/java/org/opencds/cqf/tooling/operation/ProfilesToSpreadsheet.java index 8c17ed7b1..fad1f0b55 100644 --- a/tooling/src/main/java/org/opencds/cqf/tooling/operation/ProfilesToSpreadsheet.java +++ b/tooling/src/main/java/org/opencds/cqf/tooling/operation/ProfilesToSpreadsheet.java @@ -82,10 +82,14 @@ private void createOutput(List bindingObjects) XSSFRow currentRow = firstSheet.createRow(rowCount.getAndAccumulate(1, ibo)); SpreadsheetCreatorHelper.createHeaderRow(workBook, createHeaderNameList(), currentRow); bindingObjects.forEach((bindingObject) -> { - addBindingObjectRowDataToCurrentSheet(firstSheet, rowCount.getAndAccumulate(1, ibo), bindingObject); + try { + addBindingObjectRowDataToCurrentSheet(firstSheet, rowCount.getAndAccumulate(1, ibo), bindingObject); + }catch(Exception ex){ + ex.printStackTrace(); + } }); SpreadsheetCreatorHelper.writeSpreadSheet(workBook, - IOUtils.concatFilePath(getOutputPath(), modelName + modelVersion + ".xlsx")); + IOUtils.concatFilePath(getOutputPath(), modelName + " " + modelVersion + " Profile Elements.xlsx")); } private List createHeaderNameList() { @@ -95,7 +99,7 @@ private List createHeaderNameList() { add("Conformance"); add("ValueSet"); add("ValueSetURL"); - add("Version"); + add("Binding ValueSet Version"); add("Code System URLs"); add("Must Support Y/N"); add("Cardinality"); @@ -129,11 +133,13 @@ private void addBindingObjectRowDataToCurrentSheet(XSSFSheet currentSheet, int r currentCell.setCellValue(bo.getBindingValueSetName()); currentCell = currentRow.createCell(cellCount++); - currentCell.setCellValue(bo.getBindingValueSetURL()); - link = (XSSFHyperlink)helper.createHyperlink(HyperlinkType.URL); - link.setAddress(bo.getBindingValueSetURL()); - currentCell.setHyperlink(link); - currentCell.setCellStyle(linkStyle); + if(bo.getBindingValueSetURL() != null) { + currentCell.setCellValue(bo.getBindingValueSetURL()); + link = (XSSFHyperlink) helper.createHyperlink(HyperlinkType.URL); + link.setAddress(bo.getBindingValueSetURL()); + currentCell.setHyperlink(link); + currentCell.setCellStyle(linkStyle); + } currentCell = currentRow.createCell(cellCount++); currentCell.setCellValue(bo.getBindingValueSetVersion()); diff --git a/tooling/src/main/java/org/opencds/cqf/tooling/operation/QICoreElementsToSpreadsheet.java b/tooling/src/main/java/org/opencds/cqf/tooling/operation/QICoreElementsToSpreadsheet.java index eb16cb5e0..f6ede6550 100644 --- a/tooling/src/main/java/org/opencds/cqf/tooling/operation/QICoreElementsToSpreadsheet.java +++ b/tooling/src/main/java/org/opencds/cqf/tooling/operation/QICoreElementsToSpreadsheet.java @@ -24,7 +24,7 @@ public class QICoreElementsToSpreadsheet extends StructureDefinitionToSpreadshee private int ConstraintColumn = 7; private int ConstraintColumnWidth = 85 * 256; - // example call: -ProfilesToSpreadsheet -ip=/Users/bryantaustin/Projects/FHIR-Spec -op=output -rp="4.0.1;US-Core/3.1.0;QI-Core/4.1.0" -sp=true -mn=QICore -mv=4.1.0 + // example call: -QICoreElementsToSpreadsheet -ip=/Users/bryantaustin/Projects/FHIR-Spec -op=output -rp="4.0.1;US-Core/3.1.0;QI-Core/4.1.0" -sp=true -mn=QICore -mv=4.1.0 @Override public void execute(String[] args) { for (String arg : args) { @@ -93,7 +93,7 @@ private void createOutput(List elementObjects) firstSheet.setColumnWidth(ConstraintColumn, ConstraintColumnWidth); // firstSheet.autoSizeColumn(ConstraintColumn); SpreadsheetCreatorHelper.writeSpreadSheet(workBook, - IOUtils.concatFilePath(getOutputPath(), modelName + modelVersion + ".xlsx")); + IOUtils.concatFilePath(getOutputPath(), modelName + modelVersion + " Data Elements" + ".xlsx")); } private List createHeaderNameList() {