From b2b046215437c108f1b4545c40cabe119bf1c4f9 Mon Sep 17 00:00:00 2001 From: Tadgh Date: Tue, 23 Feb 2021 18:04:53 -0500 Subject: [PATCH] Skip loading a FHIRPath object if we are older than STU3 (#2416) * Skip loading a FHIRPath object if we are older than STU3 * Change log level --- .../fhir/mdm/rules/config/MdmRuleValidator.java | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/hapi-fhir-server-mdm/src/main/java/ca/uhn/fhir/mdm/rules/config/MdmRuleValidator.java b/hapi-fhir-server-mdm/src/main/java/ca/uhn/fhir/mdm/rules/config/MdmRuleValidator.java index 959058cadbd..27a84c92d87 100644 --- a/hapi-fhir-server-mdm/src/main/java/ca/uhn/fhir/mdm/rules/config/MdmRuleValidator.java +++ b/hapi-fhir-server-mdm/src/main/java/ca/uhn/fhir/mdm/rules/config/MdmRuleValidator.java @@ -22,6 +22,7 @@ package ca.uhn.fhir.mdm.rules.config; import ca.uhn.fhir.context.ConfigurationException; import ca.uhn.fhir.context.FhirContext; +import ca.uhn.fhir.context.FhirVersionEnum; import ca.uhn.fhir.context.RuntimeResourceDefinition; import ca.uhn.fhir.fhirpath.IFhirPath; import ca.uhn.fhir.mdm.api.MdmConstants; @@ -61,7 +62,12 @@ public class MdmRuleValidator implements IMdmRuleValidator { public MdmRuleValidator(FhirContext theFhirContext, ISearchParamRetriever theSearchParamRetriever) { myFhirContext = theFhirContext; myTerser = myFhirContext.newTerser(); - myFhirPath = myFhirContext.newFhirPath(); + if (myFhirContext.getVersion().getVersion().isEqualOrNewerThan(FhirVersionEnum.DSTU3)) { + myFhirPath = myFhirContext.newFhirPath(); + } else { + ourLog.debug("Skipping FHIRPath validation as DSTU2 does not support FHIR"); + myFhirPath = null; + } mySearchParamRetriever = theSearchParamRetriever; } @@ -193,7 +199,11 @@ public class MdmRuleValidator implements IMdmRuleValidator { } } else { //Try to validate the FHIRPath try { - myFhirPath.parse(theResourceType + "." + theFieldMatch.getFhirPath()); + if (myFhirPath != null) { + myFhirPath.parse(theResourceType + "." + theFieldMatch.getFhirPath()); + } else { + ourLog.debug("Can't validate FHIRPath expression due to a lack of IFhirPath object."); + } } catch (Exception e) { throw new ConfigurationException("MatchField [" + theFieldMatch.getName() + "] resourceType [" + theFieldMatch.getResourceType() + "] has failed FHIRPath evaluation. " + e.getMessage()); }