Handle more than one expectation extensions

This commit is contained in:
Vassil Peytchev 2024-05-21 15:45:16 -05:00
parent 518e9da333
commit f51e055f4a
1 changed files with 44 additions and 12 deletions

View File

@ -12,6 +12,7 @@ import javax.annotation.Nullable;
import org.hl7.fhir.exceptions.DefinitionException;
import org.hl7.fhir.exceptions.FHIRFormatError;
import org.hl7.fhir.exceptions.FHIRException;
import org.hl7.fhir.r5.model.CanonicalResource;
import org.hl7.fhir.r5.model.CanonicalType;
import org.hl7.fhir.r5.model.CapabilityStatement;
@ -26,6 +27,7 @@ import org.hl7.fhir.r5.model.CapabilityStatement.SystemRestfulInteraction;
import org.hl7.fhir.r5.model.CapabilityStatement.TypeRestfulInteraction;
import org.hl7.fhir.r5.model.CodeType;
import org.hl7.fhir.r5.model.CodeableConcept;
import org.hl7.fhir.r5.model.Element;
import org.hl7.fhir.r5.model.Enumeration;
import org.hl7.fhir.r5.model.Enumerations.FHIRVersion;
import org.hl7.fhir.r5.model.Extension;
@ -43,6 +45,7 @@ import org.hl7.fhir.utilities.Utilities;
import org.hl7.fhir.utilities.xhtml.NodeType;
import org.hl7.fhir.utilities.xhtml.XhtmlNode;
public class CapabilityStatementRenderer extends ResourceRenderer {
private static final String EXPECTATION = "http://hl7.org/fhir/StructureDefinition/capabilitystatement-expectation";
@ -54,6 +57,8 @@ public class CapabilityStatementRenderer extends ResourceRenderer {
private String currentFhirBase = "";
private String collapseClass = "panel-collapse in";
private boolean multExpectationsPresent = false;
//Private classes for driving the rendering
private class CombinedSearchParamSet {
@ -346,6 +351,10 @@ public class CapabilityStatementRenderer extends ResourceRenderer {
}
}
if (multExpectationsPresent) {
addWarningPanel(x,"⹋⹋ - this mark indicates that there are more than one expectation extensions present");
}
return true;
}
@ -817,7 +826,7 @@ public class CapabilityStatementRenderer extends ResourceRenderer {
private List<String> getCombinedParams(List<String> paramNames, List<Extension> paramExtensions) {
for (Extension e : paramExtensions) {
String capExpectation = e.getExtensionString(EXPECTATION);
String capExpectation = expectationForDisplay(e,EXPECTATION);
if (!Utilities.noString(capExpectation)) {
if (capExpectation.equals("SHALL") || capExpectation.equals("SHOULD") || capExpectation.equals("MAY")) {
paramNames.add(printCombinedParams(e));
@ -890,7 +899,7 @@ public class CapabilityStatementRenderer extends ResourceRenderer {
private List<String> getParams(List<String> paramNames, List<CapabilityStatementRestResourceSearchParamComponent> params) {
for (CapabilityStatementRestResourceSearchParamComponent p : params) {
String capExpectation = p.getExtensionString(EXPECTATION);
String capExpectation = expectationForDisplay(p,EXPECTATION);
if (!Utilities.noString(capExpectation)) {
if (capExpectation.equals("SHALL") || capExpectation.equals("SHOULD") || capExpectation.equals("MAY")) {
paramNames.add(p.getName());
@ -938,7 +947,7 @@ public class CapabilityStatementRenderer extends ResourceRenderer {
private List<String> getStringListFromOperations(List<CapabilityStatementRestResourceOperationComponent> list) {
List<String> result = new ArrayList<String>();
for (CapabilityStatementRestResourceOperationComponent op : list) {
String capExpectation = op.getExtensionString(EXPECTATION);
String capExpectation = expectationForDisplay(op,EXPECTATION);
if (!Utilities.noString(capExpectation)) {
if (capExpectation.equals("SHALL") || capExpectation.equals("SHOULD") || capExpectation.equals("MAY")) {
result.add("$"+op.getName());
@ -1082,7 +1091,7 @@ public class CapabilityStatementRenderer extends ResourceRenderer {
ResourceOperations ops = new ResourceOperations();
for ( CapabilityStatementRestResourceOperationComponent op : opList) {
capExpectation = op.getExtensionString(EXPECTATION);
capExpectation = expectationForDisplay(op,EXPECTATION);
if (Utilities.noString(capExpectation)) {
capExpectation = "supported";
}
@ -1102,7 +1111,7 @@ public class CapabilityStatementRenderer extends ResourceRenderer {
List<String> supporteds = new ArrayList<String>();
for (ResourceInteractionComponent op : r.getInteraction()) {
capExpectation = op.getExtensionString(EXPECTATION);
capExpectation = expectationForDisplay(op,EXPECTATION);
if (!Utilities.noString(capExpectation)) {
switch(capExpectation) {
case "SHALL" : shalls.add(op.getCode().toCode());
@ -1135,7 +1144,7 @@ public class CapabilityStatementRenderer extends ResourceRenderer {
String capExpectation;
SingleParam param;
for ( CapabilityStatementRestResourceSearchParamComponent sp : r.getSearchParam()) {
capExpectation = sp.getExtensionString(EXPECTATION);
capExpectation = expectationForDisplay(sp,EXPECTATION);
if (Utilities.noString(capExpectation)) {
capExpectation = "supported";
}
@ -1147,7 +1156,7 @@ public class CapabilityStatementRenderer extends ResourceRenderer {
CombinedSearchParamSet combinedParams;
String paramName;
for (Extension e : r.getExtensionsByUrl(COMBINED)) {
capExpectation = e.getExtensionString(EXPECTATION);
capExpectation = expectationForDisplay(e,EXPECTATION);
if (Utilities.noString(capExpectation)) {
capExpectation = "supported";
}
@ -1387,14 +1396,14 @@ public class CapabilityStatementRenderer extends ResourceRenderer {
return stringList;
}
private String getResourceExpectation(CapabilityStatementRestResourceComponent r) {
String capExpectation = r.getExtensionString(EXPECTATION);
String capExpectation = expectationForDisplay(r,EXPECTATION);
if (!Utilities.noString(capExpectation)) return capExpectation;
boolean shalls = false;
boolean shoulds = false;
boolean mays = false;
boolean shouldnots = false;
for (ResourceInteractionComponent ric : r.getInteraction()) {
capExpectation = ric.getExtensionString(EXPECTATION);
capExpectation = expectationForDisplay(ric,EXPECTATION);
if (!Utilities.noString(capExpectation)) {
switch(capExpectation) {
case "SHALL" : shalls = true;
@ -1411,7 +1420,7 @@ public class CapabilityStatementRenderer extends ResourceRenderer {
if (shalls) return "SHALL";
//Check search parameters requirements
for ( CapabilityStatementRestResourceSearchParamComponent sp : r.getSearchParam()) {
capExpectation = sp.getExtensionString(EXPECTATION);
capExpectation = expectationForDisplay(sp,EXPECTATION);
if (!Utilities.noString(capExpectation)) {
switch(capExpectation) {
case "SHALL" : shalls = true;
@ -1433,7 +1442,7 @@ public class CapabilityStatementRenderer extends ResourceRenderer {
}
private String getProfileExpectation(CanonicalType r) {
String capExpectation = r.getExtensionString(EXPECTATION);
String capExpectation = expectationForDisplay(r,EXPECTATION);
if (!Utilities.noString(capExpectation)) return capExpectation;
return "SHALL";
}
@ -1494,4 +1503,27 @@ public class CapabilityStatementRenderer extends ResourceRenderer {
}
}
private String expectationForDisplay(Element e, String url) {
String result;
try {
result = e.getExtensionString(url);
return result;
}
catch (FHIRException fex) {
List<Extension> ext = e.getExtensionsByUrl(url);
if (ext.isEmpty())
return null;
if (!ext.get(0).hasValue())
return null;
multExpectationsPresent = true;
return ext.get(0).getValue().primitiveValue() + "-⹋⹋";
}
}
private void addWarningPanel(XhtmlNode node, String text) {
XhtmlNode panel = node.addTag("div").attribute("class","panel panel-danger").addTag("div").attribute("class","panel-body");
panel.addTag("span").attribute("class","label label-danger").addText("Error detected");
panel.addText(" " + text);
}
}