Merge remote-tracking branch 'origin/master' into dotasek-primitivetype-conversion-via-stringvalue
This commit is contained in:
commit
6e45dd522e
|
@ -5,7 +5,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>ca.uhn.hapi.fhir</groupId>
|
<groupId>ca.uhn.hapi.fhir</groupId>
|
||||||
<artifactId>org.hl7.fhir.core</artifactId>
|
<artifactId>org.hl7.fhir.core</artifactId>
|
||||||
<version>5.6.39-SNAPSHOT</version>
|
<version>5.6.40-SNAPSHOT</version>
|
||||||
<relativePath>../pom.xml</relativePath>
|
<relativePath>../pom.xml</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
|
|
@ -96,7 +96,7 @@ public class DicomPackageBuilder {
|
||||||
vs.setId("all");
|
vs.setId("all");
|
||||||
vs.setUrl("http://dicom.nema.org/resources/ValueSet/all");
|
vs.setUrl("http://dicom.nema.org/resources/ValueSet/all");
|
||||||
vs.setVersion(version);
|
vs.setVersion(version);
|
||||||
vs.setName("All DICOMTerminologyDefinitions");
|
vs.setName("AllDICOMTerminologyDefinitions");
|
||||||
vs.setTitle("All DICOM Controlled Terminology Definitions");
|
vs.setTitle("All DICOM Controlled Terminology Definitions");
|
||||||
vs.setStatus(PublicationStatus.ACTIVE);
|
vs.setStatus(PublicationStatus.ACTIVE);
|
||||||
vs.setExperimental(false);
|
vs.setExperimental(false);
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>ca.uhn.hapi.fhir</groupId>
|
<groupId>ca.uhn.hapi.fhir</groupId>
|
||||||
<artifactId>org.hl7.fhir.core</artifactId>
|
<artifactId>org.hl7.fhir.core</artifactId>
|
||||||
<version>5.6.39-SNAPSHOT</version>
|
<version>5.6.40-SNAPSHOT</version>
|
||||||
<relativePath>../pom.xml</relativePath>
|
<relativePath>../pom.xml</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>ca.uhn.hapi.fhir</groupId>
|
<groupId>ca.uhn.hapi.fhir</groupId>
|
||||||
<artifactId>org.hl7.fhir.core</artifactId>
|
<artifactId>org.hl7.fhir.core</artifactId>
|
||||||
<version>5.6.39-SNAPSHOT</version>
|
<version>5.6.40-SNAPSHOT</version>
|
||||||
<relativePath>../pom.xml</relativePath>
|
<relativePath>../pom.xml</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>ca.uhn.hapi.fhir</groupId>
|
<groupId>ca.uhn.hapi.fhir</groupId>
|
||||||
<artifactId>org.hl7.fhir.core</artifactId>
|
<artifactId>org.hl7.fhir.core</artifactId>
|
||||||
<version>5.6.39-SNAPSHOT</version>
|
<version>5.6.40-SNAPSHOT</version>
|
||||||
<relativePath>../pom.xml</relativePath>
|
<relativePath>../pom.xml</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>ca.uhn.hapi.fhir</groupId>
|
<groupId>ca.uhn.hapi.fhir</groupId>
|
||||||
<artifactId>org.hl7.fhir.core</artifactId>
|
<artifactId>org.hl7.fhir.core</artifactId>
|
||||||
<version>5.6.39-SNAPSHOT</version>
|
<version>5.6.40-SNAPSHOT</version>
|
||||||
<relativePath>../pom.xml</relativePath>
|
<relativePath>../pom.xml</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>ca.uhn.hapi.fhir</groupId>
|
<groupId>ca.uhn.hapi.fhir</groupId>
|
||||||
<artifactId>org.hl7.fhir.core</artifactId>
|
<artifactId>org.hl7.fhir.core</artifactId>
|
||||||
<version>5.6.39-SNAPSHOT</version>
|
<version>5.6.40-SNAPSHOT</version>
|
||||||
<relativePath>../pom.xml</relativePath>
|
<relativePath>../pom.xml</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>ca.uhn.hapi.fhir</groupId>
|
<groupId>ca.uhn.hapi.fhir</groupId>
|
||||||
<artifactId>org.hl7.fhir.core</artifactId>
|
<artifactId>org.hl7.fhir.core</artifactId>
|
||||||
<version>5.6.39-SNAPSHOT</version>
|
<version>5.6.40-SNAPSHOT</version>
|
||||||
<relativePath>../pom.xml</relativePath>
|
<relativePath>../pom.xml</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
|
|
@ -2524,6 +2524,9 @@ public class ProfileUtilities extends TranslatingUtilities {
|
||||||
}
|
}
|
||||||
|
|
||||||
public static String processRelativeUrls(String markdown, String webUrl, String basePath, List<String> resourceNames, Set<String> filenames, boolean processRelatives) {
|
public static String processRelativeUrls(String markdown, String webUrl, String basePath, List<String> resourceNames, Set<String> filenames, boolean processRelatives) {
|
||||||
|
if (markdown == null) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
StringBuilder b = new StringBuilder();
|
StringBuilder b = new StringBuilder();
|
||||||
int i = 0;
|
int i = 0;
|
||||||
while (i < markdown.length()) {
|
while (i < markdown.length()) {
|
||||||
|
@ -2818,7 +2821,9 @@ public class ProfileUtilities extends TranslatingUtilities {
|
||||||
ElementDefinition e = profile.getSnapshot().getElement().get(0);
|
ElementDefinition e = profile.getSnapshot().getElement().get(0);
|
||||||
String webroot = profile.getUserString("webroot");
|
String webroot = profile.getUserString("webroot");
|
||||||
|
|
||||||
base.setDefinition(processRelativeUrls(e.getDefinition(), webroot, baseSpecUrl(), context.getResourceNames(), masterSourceFileNames, true));
|
if (e.hasDefinition()) {
|
||||||
|
base.setDefinition(processRelativeUrls(e.getDefinition(), webroot, baseSpecUrl(), context.getResourceNames(), masterSourceFileNames, true));
|
||||||
|
}
|
||||||
base.setShort(e.getShort());
|
base.setShort(e.getShort());
|
||||||
if (e.hasCommentElement())
|
if (e.hasCommentElement())
|
||||||
base.setCommentElement(e.getCommentElement());
|
base.setCommentElement(e.getCommentElement());
|
||||||
|
|
|
@ -130,6 +130,7 @@ public class CanonicalResourceManager<T extends CanonicalResource> {
|
||||||
synchronized (this) {
|
synchronized (this) {
|
||||||
resource = res;
|
resource = res;
|
||||||
}
|
}
|
||||||
|
resource.setUserData("package", packageInfo);
|
||||||
proxy = null;
|
proxy = null;
|
||||||
}
|
}
|
||||||
return resource;
|
return resource;
|
||||||
|
@ -226,6 +227,10 @@ public class CanonicalResourceManager<T extends CanonicalResource> {
|
||||||
drop(cr.getId());
|
drop(cr.getId());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (cr.resource != null) {
|
||||||
|
cr.resource.setUserData("package", cr.getPackageInfo());
|
||||||
|
}
|
||||||
|
|
||||||
// special case logic for UTG support prior to version 5
|
// special case logic for UTG support prior to version 5
|
||||||
if (cr.getPackageInfo() != null && cr.getPackageInfo().getId().startsWith("hl7.terminology")) {
|
if (cr.getPackageInfo() != null && cr.getPackageInfo().getId().startsWith("hl7.terminology")) {
|
||||||
List<CachedCanonicalResource<T>> toDrop = new ArrayList<>();
|
List<CachedCanonicalResource<T>> toDrop = new ArrayList<>();
|
||||||
|
|
|
@ -3,6 +3,7 @@ package org.hl7.fhir.r5.context;
|
||||||
import java.io.FileNotFoundException;
|
import java.io.FileNotFoundException;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Copyright (c) 2011+, HL7, Inc.
|
Copyright (c) 2011+, HL7, Inc.
|
||||||
|
@ -148,8 +149,9 @@ public interface IWorkerContext {
|
||||||
public class PackageVersion {
|
public class PackageVersion {
|
||||||
private String id;
|
private String id;
|
||||||
private String version;
|
private String version;
|
||||||
|
private Date date;
|
||||||
|
|
||||||
public PackageVersion(String source) {
|
public PackageVersion(String source, Date date) {
|
||||||
if (source == null) {
|
if (source == null) {
|
||||||
throw new Error("Source cannot be null");
|
throw new Error("Source cannot be null");
|
||||||
}
|
}
|
||||||
|
@ -158,12 +160,15 @@ public interface IWorkerContext {
|
||||||
}
|
}
|
||||||
id = source.substring(0, source.indexOf("#"));
|
id = source.substring(0, source.indexOf("#"));
|
||||||
version = source.substring(source.indexOf("#")+1);
|
version = source.substring(source.indexOf("#")+1);
|
||||||
|
this.date = date;
|
||||||
}
|
}
|
||||||
public PackageVersion(String id, String version) {
|
public PackageVersion(String id, String version, Date date) {
|
||||||
super();
|
super();
|
||||||
this.id = id;
|
this.id = id;
|
||||||
this.version = version;
|
this.version = version;
|
||||||
|
this.date = date;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getId() {
|
public String getId() {
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
|
@ -178,6 +183,9 @@ public interface IWorkerContext {
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return id+"#"+version;
|
return id+"#"+version;
|
||||||
}
|
}
|
||||||
|
public Date getDate() {
|
||||||
|
return date;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -185,8 +193,9 @@ public interface IWorkerContext {
|
||||||
private String name;
|
private String name;
|
||||||
private String canonical;
|
private String canonical;
|
||||||
private String web;
|
private String web;
|
||||||
public PackageDetails(String id, String version, String name, String canonical, String web) {
|
|
||||||
super(id, version);
|
public PackageDetails(String id, String version, String name, String canonical, String web, Date date) {
|
||||||
|
super(id, version, date);
|
||||||
this.name = name;
|
this.name = name;
|
||||||
this.canonical = canonical;
|
this.canonical = canonical;
|
||||||
this.web = web;
|
this.web = web;
|
||||||
|
|
|
@ -474,7 +474,7 @@ public class SimpleWorkerContext extends BaseWorkerContext implements IWorkerCon
|
||||||
}
|
}
|
||||||
for (String s : pi.listResources(types)) {
|
for (String s : pi.listResources(types)) {
|
||||||
try {
|
try {
|
||||||
loadDefinitionItem(s, pi.load("package", s), loader, null, new PackageVersion(pi.id(), pi.version()));
|
loadDefinitionItem(s, pi.load("package", s), loader, null, new PackageVersion(pi.id(), pi.version(), pi.dateAsDate()));
|
||||||
t++;
|
t++;
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
throw new FHIRException(formatMessage(I18nConstants.ERROR_READING__FROM_PACKAGE__, s, pi.name(), pi.version(), e.getMessage()), e);
|
throw new FHIRException(formatMessage(I18nConstants.ERROR_READING__FROM_PACKAGE__, s, pi.name(), pi.version(), e.getMessage()), e);
|
||||||
|
@ -486,7 +486,7 @@ public class SimpleWorkerContext extends BaseWorkerContext implements IWorkerCon
|
||||||
}
|
}
|
||||||
for (PackageResourceInformation pri : pi.listIndexedResources(types)) {
|
for (PackageResourceInformation pri : pi.listIndexedResources(types)) {
|
||||||
try {
|
try {
|
||||||
registerResourceFromPackage(new PackageResourceLoader(pri, loader), new PackageVersion(pi.id(), pi.version()));
|
registerResourceFromPackage(new PackageResourceLoader(pri, loader), new PackageVersion(pi.id(), pi.version(), pi.dateAsDate()));
|
||||||
t++;
|
t++;
|
||||||
} catch (FHIRException e) {
|
} catch (FHIRException e) {
|
||||||
throw new FHIRException(formatMessage(I18nConstants.ERROR_READING__FROM_PACKAGE__, pri.getFilename(), pi.name(), pi.version(), e.getMessage()), e);
|
throw new FHIRException(formatMessage(I18nConstants.ERROR_READING__FROM_PACKAGE__, pri.getFilename(), pi.name(), pi.version(), e.getMessage()), e);
|
||||||
|
|
|
@ -47,7 +47,7 @@ public class ExpressionNode {
|
||||||
Custom,
|
Custom,
|
||||||
|
|
||||||
Empty, Not, Exists, SubsetOf, SupersetOf, IsDistinct, Distinct, Count, Where, Select, All, Repeat, Aggregate, Item /*implicit from name[]*/, As, Is, Single,
|
Empty, Not, Exists, SubsetOf, SupersetOf, IsDistinct, Distinct, Count, Where, Select, All, Repeat, Aggregate, Item /*implicit from name[]*/, As, Is, Single,
|
||||||
First, Last, Tail, Skip, Take, Union, Combine, Intersect, Exclude, Iif, Upper, Lower, ToChars, IndexOf, Substring, StartsWith, EndsWith, Matches, ReplaceMatches, Contains, Replace, Length,
|
First, Last, Tail, Skip, Take, Union, Combine, Intersect, Exclude, Iif, Upper, Lower, ToChars, IndexOf, Substring, StartsWith, EndsWith, Matches, MatchesFull, ReplaceMatches, Contains, Replace, Length,
|
||||||
Children, Descendants, MemberOf, Trace, Check, Today, Now, Resolve, Extension, AllFalse, AnyFalse, AllTrue, AnyTrue,
|
Children, Descendants, MemberOf, Trace, Check, Today, Now, Resolve, Extension, AllFalse, AnyFalse, AllTrue, AnyTrue,
|
||||||
HasValue, OfType, Type, ConvertsToBoolean, ConvertsToInteger, ConvertsToString, ConvertsToDecimal, ConvertsToQuantity, ConvertsToDateTime, ConvertsToDate, ConvertsToTime, ToBoolean, ToInteger, ToString, ToDecimal, ToQuantity, ToDateTime, ToTime, ConformsTo,
|
HasValue, OfType, Type, ConvertsToBoolean, ConvertsToInteger, ConvertsToString, ConvertsToDecimal, ConvertsToQuantity, ConvertsToDateTime, ConvertsToDate, ConvertsToTime, ToBoolean, ToInteger, ToString, ToDecimal, ToQuantity, ToDateTime, ToTime, ConformsTo,
|
||||||
Round, Sqrt, Abs, Ceiling, Exp, Floor, Ln, Log, Power, Truncate,
|
Round, Sqrt, Abs, Ceiling, Exp, Floor, Ln, Log, Power, Truncate,
|
||||||
|
@ -93,6 +93,7 @@ public class ExpressionNode {
|
||||||
if (name.equals("startsWith")) return Function.StartsWith;
|
if (name.equals("startsWith")) return Function.StartsWith;
|
||||||
if (name.equals("endsWith")) return Function.EndsWith;
|
if (name.equals("endsWith")) return Function.EndsWith;
|
||||||
if (name.equals("matches")) return Function.Matches;
|
if (name.equals("matches")) return Function.Matches;
|
||||||
|
if (name.equals("matchesFull")) return Function.MatchesFull;
|
||||||
if (name.equals("replaceMatches")) return Function.ReplaceMatches;
|
if (name.equals("replaceMatches")) return Function.ReplaceMatches;
|
||||||
if (name.equals("contains")) return Function.Contains;
|
if (name.equals("contains")) return Function.Contains;
|
||||||
if (name.equals("replace")) return Function.Replace;
|
if (name.equals("replace")) return Function.Replace;
|
||||||
|
@ -190,6 +191,7 @@ public class ExpressionNode {
|
||||||
case StartsWith : return "startsWith";
|
case StartsWith : return "startsWith";
|
||||||
case EndsWith : return "endsWith";
|
case EndsWith : return "endsWith";
|
||||||
case Matches : return "matches";
|
case Matches : return "matches";
|
||||||
|
case MatchesFull : return "matchesFull";
|
||||||
case ReplaceMatches : return "replaceMatches";
|
case ReplaceMatches : return "replaceMatches";
|
||||||
case Contains : return "contains";
|
case Contains : return "contains";
|
||||||
case Replace : return "replace";
|
case Replace : return "replace";
|
||||||
|
|
|
@ -162,7 +162,7 @@ public class PatientRenderer extends ResourceRenderer {
|
||||||
String gender = null;
|
String gender = null;
|
||||||
pw = getProperty(pat, "gender");
|
pw = getProperty(pat, "gender");
|
||||||
if (valued(pw)) {
|
if (valued(pw)) {
|
||||||
pw.value().getBase().primitiveValue();
|
gender = pw.value().getBase().primitiveValue();
|
||||||
}
|
}
|
||||||
DateType dt = null;
|
DateType dt = null;
|
||||||
pw = getProperty(pat, "birthDate");
|
pw = getProperty(pat, "birthDate");
|
||||||
|
@ -182,11 +182,11 @@ public class PatientRenderer extends ResourceRenderer {
|
||||||
} else {
|
} else {
|
||||||
b.append(gender);
|
b.append(gender);
|
||||||
}
|
}
|
||||||
b.append(" ");
|
b.append(", ");
|
||||||
if (dob == null) {
|
if (dob == null) {
|
||||||
b.append("DoB Unknown");
|
b.append("DoB Unknown");
|
||||||
} else {
|
} else {
|
||||||
b.append(display(dob));
|
b.append("DoB: "+display(dob));
|
||||||
}
|
}
|
||||||
if (id != null) {
|
if (id != null) {
|
||||||
b.append(" ( ");
|
b.append(" ( ");
|
||||||
|
@ -208,10 +208,11 @@ public class PatientRenderer extends ResourceRenderer {
|
||||||
} else {
|
} else {
|
||||||
x.tx(gender);
|
x.tx(gender);
|
||||||
}
|
}
|
||||||
x.tx(" ");
|
x.tx(", ");
|
||||||
if (dob == null) {
|
if (dob == null) {
|
||||||
x.tx("DoB Unknown");
|
x.tx("DoB Unknown");
|
||||||
} else {
|
} else {
|
||||||
|
x.tx("DoB: ");
|
||||||
render(x, dob);
|
render(x, dob);
|
||||||
}
|
}
|
||||||
if (id != null) {
|
if (id != null) {
|
||||||
|
|
|
@ -32,6 +32,8 @@ package org.hl7.fhir.r5.terminologies;
|
||||||
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Calendar;
|
||||||
|
import java.util.GregorianCalendar;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
@ -41,6 +43,8 @@ import java.util.Set;
|
||||||
import org.hl7.fhir.exceptions.FHIRException;
|
import org.hl7.fhir.exceptions.FHIRException;
|
||||||
import org.hl7.fhir.exceptions.NoTerminologyServiceException;
|
import org.hl7.fhir.exceptions.NoTerminologyServiceException;
|
||||||
import org.hl7.fhir.r5.context.IWorkerContext;
|
import org.hl7.fhir.r5.context.IWorkerContext;
|
||||||
|
import org.hl7.fhir.r5.context.IWorkerContext.PackageDetails;
|
||||||
|
import org.hl7.fhir.r5.context.IWorkerContext.PackageVersion;
|
||||||
import org.hl7.fhir.r5.context.IWorkerContext.ValidationResult;
|
import org.hl7.fhir.r5.context.IWorkerContext.ValidationResult;
|
||||||
import org.hl7.fhir.r5.model.CanonicalType;
|
import org.hl7.fhir.r5.model.CanonicalType;
|
||||||
import org.hl7.fhir.r5.model.CodeSystem;
|
import org.hl7.fhir.r5.model.CodeSystem;
|
||||||
|
@ -64,6 +68,7 @@ import org.hl7.fhir.r5.utils.validation.ValidationContextCarrier.ValidationConte
|
||||||
import org.hl7.fhir.utilities.CommaSeparatedStringBuilder;
|
import org.hl7.fhir.utilities.CommaSeparatedStringBuilder;
|
||||||
import org.hl7.fhir.utilities.Utilities;
|
import org.hl7.fhir.utilities.Utilities;
|
||||||
import org.hl7.fhir.utilities.i18n.I18nConstants;
|
import org.hl7.fhir.utilities.i18n.I18nConstants;
|
||||||
|
import org.hl7.fhir.utilities.npm.PackageInfo;
|
||||||
import org.hl7.fhir.utilities.validation.ValidationMessage.IssueSeverity;
|
import org.hl7.fhir.utilities.validation.ValidationMessage.IssueSeverity;
|
||||||
import org.hl7.fhir.utilities.validation.ValidationOptions;
|
import org.hl7.fhir.utilities.validation.ValidationOptions;
|
||||||
import org.hl7.fhir.utilities.validation.ValidationOptions.ValueSetMode;
|
import org.hl7.fhir.utilities.validation.ValidationOptions.ValueSetMode;
|
||||||
|
@ -671,9 +676,17 @@ public class ValueSetCheckerSimple extends ValueSetWorker implements ValueSetChe
|
||||||
}
|
}
|
||||||
|
|
||||||
private Boolean inComponent(ConceptSetComponent vsi, int vsiIndex, String system, String code, boolean only, List<String> warnings) throws FHIRException {
|
private Boolean inComponent(ConceptSetComponent vsi, int vsiIndex, String system, String code, boolean only, List<String> warnings) throws FHIRException {
|
||||||
for (UriType uri : vsi.getValueSet()) {
|
if (isValueSetUnionImports()) {
|
||||||
if (inImport(uri.getValue(), system, code)) {
|
for (UriType uri : vsi.getValueSet()) {
|
||||||
return true;
|
if (inImport(uri.getValue(), system, code)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
for (UriType uri : vsi.getValueSet()) {
|
||||||
|
if (!inImport(uri.getValue(), system, code)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -738,6 +751,15 @@ public class ValueSetCheckerSimple extends ValueSetWorker implements ValueSetChe
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected boolean isValueSetUnionImports() {
|
||||||
|
PackageVersion p = (PackageVersion) valueset.getUserData("package");
|
||||||
|
if (p != null) {
|
||||||
|
return p.getDate().before(new GregorianCalendar(2022, Calendar.MARCH, 31).getTime());
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private boolean codeInFilter(CodeSystem cs, String system, ConceptSetFilterComponent f, String code) throws FHIRException {
|
private boolean codeInFilter(CodeSystem cs, String system, ConceptSetFilterComponent f, String code) throws FHIRException {
|
||||||
if ("concept".equals(f.getProperty()))
|
if ("concept".equals(f.getProperty()))
|
||||||
return codeInConceptFilter(cs, f, code);
|
return codeInConceptFilter(cs, f, code);
|
||||||
|
|
|
@ -66,7 +66,9 @@ import java.io.IOException;
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Calendar;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
|
import java.util.GregorianCalendar;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
@ -79,6 +81,7 @@ import org.hl7.fhir.exceptions.FHIRFormatError;
|
||||||
import org.hl7.fhir.exceptions.NoTerminologyServiceException;
|
import org.hl7.fhir.exceptions.NoTerminologyServiceException;
|
||||||
import org.hl7.fhir.exceptions.TerminologyServiceException;
|
import org.hl7.fhir.exceptions.TerminologyServiceException;
|
||||||
import org.hl7.fhir.r5.context.IWorkerContext;
|
import org.hl7.fhir.r5.context.IWorkerContext;
|
||||||
|
import org.hl7.fhir.r5.context.IWorkerContext.PackageVersion;
|
||||||
import org.hl7.fhir.r5.model.BooleanType;
|
import org.hl7.fhir.r5.model.BooleanType;
|
||||||
import org.hl7.fhir.r5.model.CodeSystem;
|
import org.hl7.fhir.r5.model.CodeSystem;
|
||||||
import org.hl7.fhir.r5.model.CodeSystem.CodeSystemContentMode;
|
import org.hl7.fhir.r5.model.CodeSystem.CodeSystemContentMode;
|
||||||
|
@ -426,8 +429,9 @@ public class ValueSetExpanderSimple extends ValueSetWorker implements ValueSetEx
|
||||||
focus.getExpansion().addParameter().setName(p.getName()).setValue(p.getValue());
|
focus.getExpansion().addParameter().setName(p.getName()).setValue(p.getValue());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (source.hasCompose())
|
if (source.hasCompose()) {
|
||||||
handleCompose(source.getCompose(), focus.getExpansion(), expParams, source.getUrl(), focus.getExpansion().getExtension());
|
handleCompose(source.getCompose(), focus.getExpansion(), expParams, source.getUrl(), focus.getExpansion().getExtension(), source);
|
||||||
|
}
|
||||||
|
|
||||||
if (canBeHeirarchy) {
|
if (canBeHeirarchy) {
|
||||||
for (ValueSetExpansionContainsComponent c : roots) {
|
for (ValueSetExpansionContainsComponent c : roots) {
|
||||||
|
@ -467,7 +471,7 @@ public class ValueSetExpanderSimple extends ValueSetWorker implements ValueSetEx
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void handleCompose(ValueSetComposeComponent compose, ValueSetExpansionComponent exp, Parameters expParams, String ctxt, List<Extension> extensions)
|
private void handleCompose(ValueSetComposeComponent compose, ValueSetExpansionComponent exp, Parameters expParams, String ctxt, List<Extension> extensions, ValueSet valueSet)
|
||||||
throws ETooCostly, FileNotFoundException, IOException, FHIRException {
|
throws ETooCostly, FileNotFoundException, IOException, FHIRException {
|
||||||
compose.checkNoModifiers("ValueSet.compose", "expanding");
|
compose.checkNoModifiers("ValueSet.compose", "expanding");
|
||||||
// Exclude comes first because we build up a map of things to exclude
|
// Exclude comes first because we build up a map of things to exclude
|
||||||
|
@ -481,11 +485,11 @@ public class ValueSetExpanderSimple extends ValueSetWorker implements ValueSetEx
|
||||||
first = false;
|
first = false;
|
||||||
else
|
else
|
||||||
canBeHeirarchy = false;
|
canBeHeirarchy = false;
|
||||||
includeCodes(inc, exp, expParams, canBeHeirarchy, compose.hasInactive() && !compose.getInactive(), extensions);
|
includeCodes(inc, exp, expParams, canBeHeirarchy, compose.hasInactive() && !compose.getInactive(), extensions, valueSet);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private ValueSet importValueSet(String value, ValueSetExpansionComponent exp, Parameters expParams, boolean noInactive) throws ETooCostly, TerminologyServiceException, FileNotFoundException, IOException, FHIRFormatError {
|
private ValueSet importValueSet(String value, ValueSetExpansionComponent exp, Parameters expParams, boolean noInactive, ValueSet valueSet) throws ETooCostly, TerminologyServiceException, FileNotFoundException, IOException, FHIRFormatError {
|
||||||
if (value == null)
|
if (value == null)
|
||||||
throw fail("unable to find value set with no identity");
|
throw fail("unable to find value set with no identity");
|
||||||
ValueSet vs = context.fetchResource(ValueSet.class, value);
|
ValueSet vs = context.fetchResource(ValueSet.class, value);
|
||||||
|
@ -521,10 +525,22 @@ public class ValueSetExpanderSimple extends ValueSetWorker implements ValueSetEx
|
||||||
if (!existsInParams(exp.getParameter(), p.getName(), p.getValue()))
|
if (!existsInParams(exp.getParameter(), p.getName(), p.getValue()))
|
||||||
exp.getParameter().add(p);
|
exp.getParameter().add(p);
|
||||||
}
|
}
|
||||||
copyExpansion(vso.getValueset().getExpansion().getContains());
|
if (isValueSetUnionImports(valueSet)) {
|
||||||
|
copyExpansion(vso.getValueset().getExpansion().getContains());
|
||||||
|
}
|
||||||
canBeHeirarchy = false; // if we're importing a value set, we have to be combining, so we won't try for a heirarchy
|
canBeHeirarchy = false; // if we're importing a value set, we have to be combining, so we won't try for a heirarchy
|
||||||
return vso.getValueset();
|
return vso.getValueset();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
protected boolean isValueSetUnionImports(ValueSet valueSet) {
|
||||||
|
PackageVersion p = (PackageVersion) valueSet.getUserData("package");
|
||||||
|
if (p != null) {
|
||||||
|
return p.getDate().before(new GregorianCalendar(2022, Calendar.MARCH, 31).getTime());
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void copyExpansion(List<ValueSetExpansionContainsComponent> list) {
|
public void copyExpansion(List<ValueSetExpansionContainsComponent> list) {
|
||||||
for (ValueSetExpansionContainsComponent cc : list) {
|
for (ValueSetExpansionContainsComponent cc : list) {
|
||||||
|
@ -562,11 +578,11 @@ public class ValueSetExpanderSimple extends ValueSetWorker implements ValueSetEx
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void includeCodes(ConceptSetComponent inc, ValueSetExpansionComponent exp, Parameters expParams, boolean heirarchical, boolean noInactive, List<Extension> extensions) throws ETooCostly, FileNotFoundException, IOException, FHIRException {
|
private void includeCodes(ConceptSetComponent inc, ValueSetExpansionComponent exp, Parameters expParams, boolean heirarchical, boolean noInactive, List<Extension> extensions, ValueSet valueSet) throws ETooCostly, FileNotFoundException, IOException, FHIRException {
|
||||||
inc.checkNoModifiers("Compose.include", "expanding");
|
inc.checkNoModifiers("Compose.include", "expanding");
|
||||||
List<ValueSet> imports = new ArrayList<ValueSet>();
|
List<ValueSet> imports = new ArrayList<ValueSet>();
|
||||||
for (UriType imp : inc.getValueSet()) {
|
for (UriType imp : inc.getValueSet()) {
|
||||||
imports.add(importValueSet(imp.getValue(), exp, expParams, noInactive));
|
imports.add(importValueSet(imp.getValue(), exp, expParams, noInactive, valueSet));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!inc.hasSystem()) {
|
if (!inc.hasSystem()) {
|
||||||
|
|
|
@ -14,8 +14,11 @@ import java.util.HashSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
import java.util.regex.Matcher;
|
||||||
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
import org.apache.commons.lang3.NotImplementedException;
|
import org.apache.commons.lang3.NotImplementedException;
|
||||||
|
import org.apache.commons.lang3.RegExUtils;
|
||||||
import org.fhir.ucum.Decimal;
|
import org.fhir.ucum.Decimal;
|
||||||
import org.fhir.ucum.Pair;
|
import org.fhir.ucum.Pair;
|
||||||
import org.fhir.ucum.UcumException;
|
import org.fhir.ucum.UcumException;
|
||||||
|
@ -1322,6 +1325,7 @@ public class FHIRPathEngine {
|
||||||
case StartsWith: return checkParamCount(lexer, location, exp, 1);
|
case StartsWith: return checkParamCount(lexer, location, exp, 1);
|
||||||
case EndsWith: return checkParamCount(lexer, location, exp, 1);
|
case EndsWith: return checkParamCount(lexer, location, exp, 1);
|
||||||
case Matches: return checkParamCount(lexer, location, exp, 1);
|
case Matches: return checkParamCount(lexer, location, exp, 1);
|
||||||
|
case MatchesFull: return checkParamCount(lexer, location, exp, 1);
|
||||||
case ReplaceMatches: return checkParamCount(lexer, location, exp, 2);
|
case ReplaceMatches: return checkParamCount(lexer, location, exp, 2);
|
||||||
case Contains: return checkParamCount(lexer, location, exp, 1);
|
case Contains: return checkParamCount(lexer, location, exp, 1);
|
||||||
case Replace: return checkParamCount(lexer, location, exp, 2);
|
case Replace: return checkParamCount(lexer, location, exp, 2);
|
||||||
|
@ -3156,6 +3160,11 @@ public class FHIRPathEngine {
|
||||||
checkParamTypes(exp, exp.getFunction().toCode(), paramTypes, new TypeDetails(CollectionStatus.SINGLETON, TypeDetails.FP_String));
|
checkParamTypes(exp, exp.getFunction().toCode(), paramTypes, new TypeDetails(CollectionStatus.SINGLETON, TypeDetails.FP_String));
|
||||||
return new TypeDetails(CollectionStatus.SINGLETON, TypeDetails.FP_Boolean);
|
return new TypeDetails(CollectionStatus.SINGLETON, TypeDetails.FP_Boolean);
|
||||||
}
|
}
|
||||||
|
case MatchesFull : {
|
||||||
|
checkContextString(focus, "matches", exp);
|
||||||
|
checkParamTypes(exp, exp.getFunction().toCode(), paramTypes, new TypeDetails(CollectionStatus.SINGLETON, TypeDetails.FP_String));
|
||||||
|
return new TypeDetails(CollectionStatus.SINGLETON, TypeDetails.FP_Boolean);
|
||||||
|
}
|
||||||
case ReplaceMatches : {
|
case ReplaceMatches : {
|
||||||
checkContextString(focus, "replaceMatches", exp);
|
checkContextString(focus, "replaceMatches", exp);
|
||||||
checkParamTypes(exp, exp.getFunction().toCode(), paramTypes, new TypeDetails(CollectionStatus.SINGLETON, TypeDetails.FP_String), new TypeDetails(CollectionStatus.SINGLETON, TypeDetails.FP_String));
|
checkParamTypes(exp, exp.getFunction().toCode(), paramTypes, new TypeDetails(CollectionStatus.SINGLETON, TypeDetails.FP_String), new TypeDetails(CollectionStatus.SINGLETON, TypeDetails.FP_String));
|
||||||
|
@ -3456,6 +3465,7 @@ public class FHIRPathEngine {
|
||||||
case StartsWith : return funcStartsWith(context, focus, exp);
|
case StartsWith : return funcStartsWith(context, focus, exp);
|
||||||
case EndsWith : return funcEndsWith(context, focus, exp);
|
case EndsWith : return funcEndsWith(context, focus, exp);
|
||||||
case Matches : return funcMatches(context, focus, exp);
|
case Matches : return funcMatches(context, focus, exp);
|
||||||
|
case MatchesFull : return funcMatchesFull(context, focus, exp);
|
||||||
case ReplaceMatches : return funcReplaceMatches(context, focus, exp);
|
case ReplaceMatches : return funcReplaceMatches(context, focus, exp);
|
||||||
case Contains : return funcContains(context, focus, exp);
|
case Contains : return funcContains(context, focus, exp);
|
||||||
case Replace : return funcReplace(context, focus, exp);
|
case Replace : return funcReplace(context, focus, exp);
|
||||||
|
@ -4777,7 +4787,9 @@ public class FHIRPathEngine {
|
||||||
if (Utilities.noString(st)) {
|
if (Utilities.noString(st)) {
|
||||||
result.add(new BooleanType(false).noExtensions());
|
result.add(new BooleanType(false).noExtensions());
|
||||||
} else {
|
} else {
|
||||||
boolean ok = st.matches("(?s)" + sw);
|
Pattern p = Pattern.compile("(?s)" + sw);
|
||||||
|
Matcher m = p.matcher(st);
|
||||||
|
boolean ok = m.find();
|
||||||
result.add(new BooleanType(ok).noExtensions());
|
result.add(new BooleanType(ok).noExtensions());
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -4786,6 +4798,25 @@ public class FHIRPathEngine {
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private List<Base> funcMatchesFull(ExecutionContext context, List<Base> focus, ExpressionNode exp) throws FHIRException {
|
||||||
|
List<Base> result = new ArrayList<Base>();
|
||||||
|
String sw = convertToString(execute(context, focus, exp.getParameters().get(0), true));
|
||||||
|
|
||||||
|
if (focus.size() == 1 && !Utilities.noString(sw)) {
|
||||||
|
String st = convertToString(focus.get(0));
|
||||||
|
if (Utilities.noString(st)) {
|
||||||
|
result.add(new BooleanType(false).noExtensions());
|
||||||
|
} else {
|
||||||
|
Pattern p = Pattern.compile("(?s)" + sw);
|
||||||
|
Matcher m = p.matcher(st);
|
||||||
|
boolean ok = m.matches();
|
||||||
|
result.add(new BooleanType(ok).noExtensions());
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
result.add(new BooleanType(false).noExtensions());
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
private List<Base> funcContains(ExecutionContext context, List<Base> focus, ExpressionNode exp) throws FHIRException {
|
private List<Base> funcContains(ExecutionContext context, List<Base> focus, ExpressionNode exp) throws FHIRException {
|
||||||
List<Base> result = new ArrayList<Base>();
|
List<Base> result = new ArrayList<Base>();
|
||||||
String sw = convertToString(execute(context, focus, exp.getParameters().get(0), true));
|
String sw = convertToString(execute(context, focus, exp.getParameters().get(0), true));
|
||||||
|
|
|
@ -65,6 +65,9 @@ public class OperationOutcomeUtilities {
|
||||||
if (message.getSource() != null) {
|
if (message.getSource() != null) {
|
||||||
issue.getExtension().add(ToolingExtensions.makeIssueSource(message.getSource()));
|
issue.getExtension().add(ToolingExtensions.makeIssueSource(message.getSource()));
|
||||||
}
|
}
|
||||||
|
if (message.getMessageId() != null) {
|
||||||
|
issue.getExtension().add(ToolingExtensions.makeIssueMessageId(message.getMessageId()));
|
||||||
|
}
|
||||||
issue.setUserData("source.msg", message);
|
issue.setUserData("source.msg", message);
|
||||||
return issue;
|
return issue;
|
||||||
}
|
}
|
||||||
|
@ -111,9 +114,12 @@ public class OperationOutcomeUtilities {
|
||||||
case TIMEOUT: return IssueType.TIMEOUT;
|
case TIMEOUT: return IssueType.TIMEOUT;
|
||||||
case THROTTLED: return IssueType.THROTTLED;
|
case THROTTLED: return IssueType.THROTTLED;
|
||||||
case INFORMATIONAL: return IssueType.INFORMATIONAL;
|
case INFORMATIONAL: return IssueType.INFORMATIONAL;
|
||||||
case NULL: return IssueType.NULL;
|
case NULL: return IssueType.NULL;
|
||||||
|
case DELETED: return IssueType.DELETED;
|
||||||
|
case MULTIPLEMATCHES: return IssueType.MULTIPLEMATCHES;
|
||||||
|
default:
|
||||||
|
return IssueType.NULL;
|
||||||
}
|
}
|
||||||
return IssueType.NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static OperationOutcome createOutcome(List<ValidationMessage> messages) {
|
public static OperationOutcome createOutcome(List<ValidationMessage> messages) {
|
||||||
|
|
|
@ -119,6 +119,7 @@ public class ToolingExtensions {
|
||||||
private static final String EXT_IDENTIFIER = "http://hl7.org/fhir/StructureDefinition/identifier";
|
private static final String EXT_IDENTIFIER = "http://hl7.org/fhir/StructureDefinition/identifier";
|
||||||
public static final String EXT_TRANSLATION = "http://hl7.org/fhir/StructureDefinition/translation";
|
public static final String EXT_TRANSLATION = "http://hl7.org/fhir/StructureDefinition/translation";
|
||||||
public static final String EXT_ISSUE_SOURCE = "http://hl7.org/fhir/StructureDefinition/operationoutcome-issue-source";
|
public static final String EXT_ISSUE_SOURCE = "http://hl7.org/fhir/StructureDefinition/operationoutcome-issue-source";
|
||||||
|
public static final String EXT_ISSUE_MSG_ID = "http://hl7.org/fhir/StructureDefinition/operationoutcome-message-id";
|
||||||
public static final String EXT_ISSUE_LINE = "http://hl7.org/fhir/StructureDefinition/operationoutcome-issue-line";
|
public static final String EXT_ISSUE_LINE = "http://hl7.org/fhir/StructureDefinition/operationoutcome-issue-line";
|
||||||
public static final String EXT_ISSUE_COL = "http://hl7.org/fhir/StructureDefinition/operationoutcome-issue-col";
|
public static final String EXT_ISSUE_COL = "http://hl7.org/fhir/StructureDefinition/operationoutcome-issue-col";
|
||||||
public static final String EXT_DISPLAY_HINT = "http://hl7.org/fhir/StructureDefinition/structuredefinition-display-hint";
|
public static final String EXT_DISPLAY_HINT = "http://hl7.org/fhir/StructureDefinition/structuredefinition-display-hint";
|
||||||
|
@ -214,6 +215,16 @@ public class ToolingExtensions {
|
||||||
return ex;
|
return ex;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static Extension makeIssueMessageId(String msgId) {
|
||||||
|
Extension ex = new Extension();
|
||||||
|
// todo: write this up and get it published with the pack (and handle the redirect?)
|
||||||
|
ex.setUrl(ToolingExtensions.EXT_ISSUE_MSG_ID);
|
||||||
|
CodeType c = new CodeType();
|
||||||
|
c.setValue(msgId);
|
||||||
|
ex.setValue(c);
|
||||||
|
return ex;
|
||||||
|
}
|
||||||
|
|
||||||
public static boolean hasExtension(DomainResource de, String url) {
|
public static boolean hasExtension(DomainResource de, String url) {
|
||||||
return getExtension(de, url) != null;
|
return getExtension(de, url) != null;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,7 @@
|
||||||
package org.hl7.fhir.r5.test;
|
package org.hl7.fhir.r5.test;
|
||||||
|
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
import org.hl7.fhir.r5.context.CanonicalResourceManager;
|
import org.hl7.fhir.r5.context.CanonicalResourceManager;
|
||||||
import org.hl7.fhir.r5.context.CanonicalResourceManager.CanonicalResourceProxy;
|
import org.hl7.fhir.r5.context.CanonicalResourceManager.CanonicalResourceProxy;
|
||||||
import org.hl7.fhir.r5.context.IWorkerContext.PackageVersion;
|
import org.hl7.fhir.r5.context.IWorkerContext.PackageVersion;
|
||||||
|
@ -425,14 +427,13 @@ public class CanonicalResourceManagerTests {
|
||||||
vs2.setUrl("http://terminology.hl7.org/ValueSet/234");
|
vs2.setUrl("http://terminology.hl7.org/ValueSet/234");
|
||||||
vs2.setVersion("2000.0.0");
|
vs2.setVersion("2000.0.0");
|
||||||
vs2.setName("2");
|
vs2.setName("2");
|
||||||
|
|
||||||
|
|
||||||
mrm.see(vs1, new PackageVersion("hl7.fhir.r4.core", "4.0.1"));
|
mrm.see(vs1, new PackageVersion("hl7.fhir.r4.core", "4.0.1", new Date()));
|
||||||
Assertions.assertNotNull(mrm.get("http://terminology.hl7.org/ValueSet/234"));
|
Assertions.assertNotNull(mrm.get("http://terminology.hl7.org/ValueSet/234"));
|
||||||
Assertions.assertNotNull(mrm.get("http://terminology.hl7.org/ValueSet/234", "2.0.0"));
|
Assertions.assertNotNull(mrm.get("http://terminology.hl7.org/ValueSet/234", "2.0.0"));
|
||||||
Assertions.assertTrue(mrm.get("http://terminology.hl7.org/ValueSet/234").getName().equals("1"));
|
Assertions.assertTrue(mrm.get("http://terminology.hl7.org/ValueSet/234").getName().equals("1"));
|
||||||
|
|
||||||
mrm.see(vs2, new PackageVersion("hl7.terminology.r4", "4.0.1"));
|
mrm.see(vs2, new PackageVersion("hl7.terminology.r4", "4.0.1", new Date()));
|
||||||
Assertions.assertNotNull(mrm.get("http://terminology.hl7.org/ValueSet/234"));
|
Assertions.assertNotNull(mrm.get("http://terminology.hl7.org/ValueSet/234"));
|
||||||
Assertions.assertTrue(mrm.get("http://terminology.hl7.org/ValueSet/234").getName().equals("2"));
|
Assertions.assertTrue(mrm.get("http://terminology.hl7.org/ValueSet/234").getName().equals("2"));
|
||||||
Assertions.assertNull(mrm.get("http://terminology.hl7.org/ValueSet/234", "2.0.0")); // this will get dropped completely because of UTG rules
|
Assertions.assertNull(mrm.get("http://terminology.hl7.org/ValueSet/234", "2.0.0")); // this will get dropped completely because of UTG rules
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>ca.uhn.hapi.fhir</groupId>
|
<groupId>ca.uhn.hapi.fhir</groupId>
|
||||||
<artifactId>org.hl7.fhir.core</artifactId>
|
<artifactId>org.hl7.fhir.core</artifactId>
|
||||||
<version>5.6.39-SNAPSHOT</version>
|
<version>5.6.40-SNAPSHOT</version>
|
||||||
<relativePath>../pom.xml</relativePath>
|
<relativePath>../pom.xml</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>ca.uhn.hapi.fhir</groupId>
|
<groupId>ca.uhn.hapi.fhir</groupId>
|
||||||
<artifactId>org.hl7.fhir.core</artifactId>
|
<artifactId>org.hl7.fhir.core</artifactId>
|
||||||
<version>5.6.39-SNAPSHOT</version>
|
<version>5.6.40-SNAPSHOT</version>
|
||||||
<relativePath>../pom.xml</relativePath>
|
<relativePath>../pom.xml</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
|
|
@ -622,6 +622,7 @@ public class I18nConstants {
|
||||||
public static final String VALUESET_REFERENCE_UNKNOWN = "VALUESET_REFERENCE_UNKNOWN";
|
public static final String VALUESET_REFERENCE_UNKNOWN = "VALUESET_REFERENCE_UNKNOWN";
|
||||||
public static final String VALUESET_UNC_SYSTEM_WARNING = "VALUESET_UNC_SYSTEM_WARNING";
|
public static final String VALUESET_UNC_SYSTEM_WARNING = "VALUESET_UNC_SYSTEM_WARNING";
|
||||||
public static final String VALUESET_UNC_SYSTEM_WARNING_VER = "VALUESET_UNC_SYSTEM_WARNING_VER";
|
public static final String VALUESET_UNC_SYSTEM_WARNING_VER = "VALUESET_UNC_SYSTEM_WARNING_VER";
|
||||||
|
public static final String VALUESET_IMPORT_UNION_INTERSECTION = "VALUESET_IMPORT_UNION_INTERSECTION";
|
||||||
public static final String VERSION_MISMATCH_THE_CONTEXT_HAS_VERSION__LOADED_AND_THE_NEW_CONTENT_BEING_LOADED_IS_VERSION_ = "Version_mismatch_The_context_has_version__loaded_and_the_new_content_being_loaded_is_version_";
|
public static final String VERSION_MISMATCH_THE_CONTEXT_HAS_VERSION__LOADED_AND_THE_NEW_CONTENT_BEING_LOADED_IS_VERSION_ = "Version_mismatch_The_context_has_version__loaded_and_the_new_content_being_loaded_is_version_";
|
||||||
public static final String WRONG_NAMESPACE__EXPECTED_ = "Wrong_namespace__expected_";
|
public static final String WRONG_NAMESPACE__EXPECTED_ = "Wrong_namespace__expected_";
|
||||||
public static final String WRONG_TYPE_FOR_RESOURCE = "Wrong_type_for_resource";
|
public static final String WRONG_TYPE_FOR_RESOURCE = "Wrong_type_for_resource";
|
||||||
|
|
|
@ -42,9 +42,12 @@ import java.io.InputStream;
|
||||||
import java.io.OutputStream;
|
import java.io.OutputStream;
|
||||||
import java.nio.charset.Charset;
|
import java.nio.charset.Charset;
|
||||||
import java.nio.charset.StandardCharsets;
|
import java.nio.charset.StandardCharsets;
|
||||||
|
import java.text.ParseException;
|
||||||
|
import java.text.SimpleDateFormat;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.Comparator;
|
import java.util.Comparator;
|
||||||
|
import java.util.Date;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
@ -1086,7 +1089,7 @@ public class NpmPackage {
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isCore() {
|
public boolean isCore() {
|
||||||
return "fhir.core".equals(JSONUtil.str(npm, "type"));
|
return Utilities.existsInList(JSONUtil.str(npm, "type"), "fhir.core", "Core");
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean hasCanonical(String url) {
|
public boolean hasCanonical(String url) {
|
||||||
|
@ -1134,6 +1137,28 @@ public class NpmPackage {
|
||||||
public InputStream load(PackageResourceInformation p) throws FileNotFoundException {
|
public InputStream load(PackageResourceInformation p) throws FileNotFoundException {
|
||||||
return new FileInputStream(p.filename);
|
return new FileInputStream(p.filename);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Date dateAsDate() {
|
||||||
|
try {
|
||||||
|
String d = date();
|
||||||
|
if (d == null) {
|
||||||
|
switch (name()) {
|
||||||
|
case "hl7.fhir.r2.core": d = "20151024000000"; break;
|
||||||
|
case "hl7.fhir.r2b.core": d = "20160330000000"; break;
|
||||||
|
case "hl7.fhir.r3.core": d = "20191024000000"; break;
|
||||||
|
case "hl7.fhir.r4.core": d = "20191030000000"; break;
|
||||||
|
case "hl7.fhir.r4b.core": d = "202112200000000"; break;
|
||||||
|
case "hl7.fhir.r5.core": d = "20211219000000"; break;
|
||||||
|
default:
|
||||||
|
return new Date();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return new SimpleDateFormat("yyyyMMddHHmmss").parse(d);
|
||||||
|
} catch (ParseException e) {
|
||||||
|
// this really really shouldn't happen
|
||||||
|
return new Date();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
|
@ -706,3 +706,5 @@ TYPE_SPECIFIC_CHECKS_DT_QTY_MAX_VALUE_WRONG_UCUM = The value in the instance ({0
|
||||||
TYPE_SPECIFIC_CHECKS_DT_BASE64_NO_WS_ERROR = Base64 encoded values are not allowed to contain any whitespace (per RFC 4648). Note that non-validating readers are encouraged to accept whitespace anyway
|
TYPE_SPECIFIC_CHECKS_DT_BASE64_NO_WS_ERROR = Base64 encoded values are not allowed to contain any whitespace (per RFC 4648). Note that non-validating readers are encouraged to accept whitespace anyway
|
||||||
TYPE_SPECIFIC_CHECKS_DT_BASE64_NO_WS_WARNING = Base64 encoded values SHOULD not contain any whitespace (per RFC 4648). Note that non-validating readers are encouraged to accept whitespace anyway
|
TYPE_SPECIFIC_CHECKS_DT_BASE64_NO_WS_WARNING = Base64 encoded values SHOULD not contain any whitespace (per RFC 4648). Note that non-validating readers are encouraged to accept whitespace anyway
|
||||||
SD_DERIVATION_KIND_MISMATCH = The structure definition constrains a kind of {0}, but has a different kind ({1})
|
SD_DERIVATION_KIND_MISMATCH = The structure definition constrains a kind of {0}, but has a different kind ({1})
|
||||||
|
VALUESET_IMPORT_UNION_INTERSECTION = This value set has an include with multiple imported value sets. Per issue https://jira.hl7.org/browse/FHIR-25179, there has been confusion in the past whether these value sets are unioned or intersectioned. If this value set is contained in a package published prior to March 31 2022, it will be treated as a union, otherwise it will be treated as an intersection
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>ca.uhn.hapi.fhir</groupId>
|
<groupId>ca.uhn.hapi.fhir</groupId>
|
||||||
<artifactId>org.hl7.fhir.core</artifactId>
|
<artifactId>org.hl7.fhir.core</artifactId>
|
||||||
<version>5.6.39-SNAPSHOT</version>
|
<version>5.6.40-SNAPSHOT</version>
|
||||||
<relativePath>../pom.xml</relativePath>
|
<relativePath>../pom.xml</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>ca.uhn.hapi.fhir</groupId>
|
<groupId>ca.uhn.hapi.fhir</groupId>
|
||||||
<artifactId>org.hl7.fhir.core</artifactId>
|
<artifactId>org.hl7.fhir.core</artifactId>
|
||||||
<version>5.6.39-SNAPSHOT</version>
|
<version>5.6.40-SNAPSHOT</version>
|
||||||
<relativePath>../pom.xml</relativePath>
|
<relativePath>../pom.xml</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
|
|
@ -280,7 +280,7 @@ public class ValidationEngine implements IValidatorResourceFetcher, IValidationP
|
||||||
if (userAgent != null) {
|
if (userAgent != null) {
|
||||||
contextBuilder.withUserAgent(userAgent);
|
contextBuilder.withUserAgent(userAgent);
|
||||||
}
|
}
|
||||||
context = contextBuilder.fromDefinitions(source, ValidatorUtils.loaderForVersion(version), new PackageVersion(src));
|
context = contextBuilder.fromDefinitions(source, ValidatorUtils.loaderForVersion(version), new PackageVersion(src, new Date()));
|
||||||
ValidatorUtils.grabNatives(getBinaries(), source, "http://hl7.org/fhir");
|
ValidatorUtils.grabNatives(getBinaries(), source, "http://hl7.org/fhir");
|
||||||
}
|
}
|
||||||
// ucum-essence.xml should be in the class path. if it's not, ask about how to sort this out
|
// ucum-essence.xml should be in the class path. if it's not, ask about how to sort this out
|
||||||
|
|
|
@ -5757,6 +5757,17 @@ public class InstanceValidator extends BaseValidator implements IResourceValidat
|
||||||
return "htmlChecks2()";
|
return "htmlChecks2()";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// clarification in FHIRPath spec
|
||||||
|
if (expr.equals("name.matches('[A-Z]([A-Za-z0-9_]){0,254}')")) {
|
||||||
|
return "name.matches('^[A-Z]([A-Za-z0-9_]){0,254}$')";
|
||||||
|
}
|
||||||
|
if ("eld-19".equals(key)) {
|
||||||
|
return "path.matches('^[^\\\\s\\\\.,:;\\\\\\'\"\\\\/|?!@#$%&*()\\\\[\\\\]{}]{1,64}(\\\\.[^\\\\s\\\\.,:;\\\\\\'\"\\\\/|?!@#$%&*()\\\\[\\\\]{}]{1,64}(\\\\[x\\\\])?(\\\\:[^\\\\s\\\\.]+)?)*$')";
|
||||||
|
}
|
||||||
|
if ("eld-20".equals(key)) {
|
||||||
|
return "path.matches('^[A-Za-z][A-Za-z0-9]*(\\\\.[a-z][A-Za-z0-9]*(\\\\[x])?)*$')";
|
||||||
|
}
|
||||||
|
|
||||||
// handled in 4.0.1
|
// handled in 4.0.1
|
||||||
if ("(component.empty() and hasMember.empty()) implies (dataAbsentReason or value)".equals(expr)) {
|
if ("(component.empty() and hasMember.empty()) implies (dataAbsentReason or value)".equals(expr)) {
|
||||||
return "(component.empty() and hasMember.empty()) implies (dataAbsentReason.exists() or value.exists())";
|
return "(component.empty() and hasMember.empty()) implies (dataAbsentReason.exists() or value.exists())";
|
||||||
|
|
|
@ -98,6 +98,9 @@ public class ValueSetValidator extends BaseValidator {
|
||||||
}
|
}
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
|
if (valuesets.size() > 1) {
|
||||||
|
warning(errors, IssueType.INFORMATIONAL, stack.getLiteralPath(), false, I18nConstants.VALUESET_IMPORT_UNION_INTERSECTION);
|
||||||
|
}
|
||||||
List<Element> concepts = include.getChildrenByName("concept");
|
List<Element> concepts = include.getChildrenByName("concept");
|
||||||
List<Element> filters = include.getChildrenByName("filter");
|
List<Element> filters = include.getChildrenByName("filter");
|
||||||
if (!Utilities.noString(system)) {
|
if (!Utilities.noString(system)) {
|
||||||
|
|
|
@ -0,0 +1,12 @@
|
||||||
|
-------------------------------------------------------------------------------------
|
||||||
|
{"code" : {
|
||||||
|
"system" : "http://www.ada.org/snodent",
|
||||||
|
"code" : "210965D",
|
||||||
|
"display" : "Anterior part of lower alveolar ridge"
|
||||||
|
}, "valueSet" :null, "lang":"null", "useServer":"true", "useClient":"true", "guessSystem":"false", "valueSetMode":"ALL_CHECKS", "versionFlexible":"false"}####
|
||||||
|
v: {
|
||||||
|
"display" : "Anterior part of lower alveolar ridge",
|
||||||
|
"code" : "210965D",
|
||||||
|
"system" : "http://www.ada.org/snodent"
|
||||||
|
}
|
||||||
|
-------------------------------------------------------------------------------------
|
4
pom.xml
4
pom.xml
|
@ -14,12 +14,12 @@
|
||||||
HAPI FHIR
|
HAPI FHIR
|
||||||
-->
|
-->
|
||||||
<artifactId>org.hl7.fhir.core</artifactId>
|
<artifactId>org.hl7.fhir.core</artifactId>
|
||||||
<version>5.6.39-SNAPSHOT</version>
|
<version>5.6.40-SNAPSHOT</version>
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
|
||||||
<properties>
|
<properties>
|
||||||
<hapi_fhir_version>5.4.0</hapi_fhir_version>
|
<hapi_fhir_version>5.4.0</hapi_fhir_version>
|
||||||
<validator_test_case_version>1.1.93</validator_test_case_version>
|
<validator_test_case_version>1.1.94</validator_test_case_version>
|
||||||
<junit_jupiter_version>5.7.1</junit_jupiter_version>
|
<junit_jupiter_version>5.7.1</junit_jupiter_version>
|
||||||
<junit_platform_launcher_version>1.7.1</junit_platform_launcher_version>
|
<junit_platform_launcher_version>1.7.1</junit_platform_launcher_version>
|
||||||
<maven_surefire_version>3.0.0-M5</maven_surefire_version>
|
<maven_surefire_version>3.0.0-M5</maven_surefire_version>
|
||||||
|
|
Loading…
Reference in New Issue