Merge remote-tracking branch 'origin/master' into do-20240716-fix-code-validation-for-locale
This commit is contained in:
commit
eba6868afe
|
@ -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>6.3.19-SNAPSHOT</version>
|
<version>6.3.20-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>6.3.19-SNAPSHOT</version>
|
<version>6.3.20-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>6.3.19-SNAPSHOT</version>
|
<version>6.3.20-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>6.3.19-SNAPSHOT</version>
|
<version>6.3.20-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>6.3.19-SNAPSHOT</version>
|
<version>6.3.20-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>6.3.19-SNAPSHOT</version>
|
<version>6.3.20-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>6.3.19-SNAPSHOT</version>
|
<version>6.3.20-SNAPSHOT</version>
|
||||||
<relativePath>../pom.xml</relativePath>
|
<relativePath>../pom.xml</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
|
|
@ -506,7 +506,7 @@ public class ProfileUtilities {
|
||||||
|
|
||||||
for (ElementDefinition e : list) {
|
for (ElementDefinition e : list) {
|
||||||
if (id.equals(e.getId()))
|
if (id.equals(e.getId()))
|
||||||
return getChildMap(profile, e);
|
return getChildMap(src, e);
|
||||||
}
|
}
|
||||||
throw new DefinitionException(context.formatMessage(I18nConstants.UNABLE_TO_RESOLVE_NAME_REFERENCE__AT_PATH_, element.getContentReference(), element.getPath()));
|
throw new DefinitionException(context.formatMessage(I18nConstants.UNABLE_TO_RESOLVE_NAME_REFERENCE__AT_PATH_, element.getContentReference(), element.getPath()));
|
||||||
|
|
||||||
|
|
|
@ -1810,10 +1810,11 @@ public abstract class BaseWorkerContext extends I18nBase implements IWorkerConte
|
||||||
if (cs != null && !hasCanonicalResource(pin, "tx-resource", cs.getVUrl()) && (cs.getContent() == CodeSystemContentMode.COMPLETE || cs.getContent() == CodeSystemContentMode.FRAGMENT)) {
|
if (cs != null && !hasCanonicalResource(pin, "tx-resource", cs.getVUrl()) && (cs.getContent() == CodeSystemContentMode.COMPLETE || cs.getContent() == CodeSystemContentMode.FRAGMENT)) {
|
||||||
cache = checkAddToParams(tc, pin, cs) || cache;
|
cache = checkAddToParams(tc, pin, cs) || cache;
|
||||||
}
|
}
|
||||||
for (CodeSystem supp : fetchResourcesByType(CodeSystem.class)) {
|
for (CodeSystem supp : codeSystems.getSupplements(cs)) {
|
||||||
if (supp.getContent() == CodeSystemContentMode.SUPPLEMENT && supp.getSupplements().equals(inc.getSystem())) {
|
//if (supp.getContent() == CodeSystemContentMode.SUPPLEMENT && supp.getSupplements().equals(inc.getSystem())) {
|
||||||
|
assert supp.getContent() == CodeSystemContentMode.SUPPLEMENT && supp.getSupplements().equals(inc.getSystem());
|
||||||
cache = checkAddToParams(tc, pin, supp) || cache;
|
cache = checkAddToParams(tc, pin, supp) || cache;
|
||||||
}
|
//}
|
||||||
}
|
}
|
||||||
return cache;
|
return cache;
|
||||||
}
|
}
|
||||||
|
@ -1885,8 +1886,15 @@ public abstract class BaseWorkerContext extends I18nBase implements IWorkerConte
|
||||||
} else if (p.getName().equals("status")) {
|
} else if (p.getName().equals("status")) {
|
||||||
status = ((PrimitiveType<?>) p.getValue()).asStringValue();
|
status = ((PrimitiveType<?>) p.getValue()).asStringValue();
|
||||||
} else if (p.getName().equals("x-caused-by-unknown-system")) {
|
} else if (p.getName().equals("x-caused-by-unknown-system")) {
|
||||||
err = TerminologyServiceErrorClass.CODESYSTEM_UNSUPPORTED;
|
String unkSystem = ((PrimitiveType<?>) p.getValue()).asStringValue();
|
||||||
unknownSystems.add(((PrimitiveType<?>) p.getValue()).asStringValue());
|
if (unkSystem != null && unkSystem.contains("|")) {
|
||||||
|
err = TerminologyServiceErrorClass.CODESYSTEM_UNSUPPORTED_VERSION;
|
||||||
|
system = unkSystem.substring(0, unkSystem.indexOf("|"));
|
||||||
|
version = unkSystem.substring(unkSystem.indexOf("|")+1);
|
||||||
|
} else {
|
||||||
|
err = TerminologyServiceErrorClass.CODESYSTEM_UNSUPPORTED;
|
||||||
|
unknownSystems.add(unkSystem);
|
||||||
|
}
|
||||||
} else if (p.getName().equals("x-unknown-system")) {
|
} else if (p.getName().equals("x-unknown-system")) {
|
||||||
unknownSystems.add(((PrimitiveType<?>) p.getValue()).asStringValue());
|
unknownSystems.add(((PrimitiveType<?>) p.getValue()).asStringValue());
|
||||||
} else if (p.getName().equals("warning-withdrawn")) {
|
} else if (p.getName().equals("warning-withdrawn")) {
|
||||||
|
@ -1948,6 +1956,12 @@ public abstract class BaseWorkerContext extends I18nBase implements IWorkerConte
|
||||||
res.setDefinition(new ConceptDefinitionComponent().setDisplay(display).setCode(code));
|
res.setDefinition(new ConceptDefinitionComponent().setDisplay(display).setCode(code));
|
||||||
res.setDisplay(display);
|
res.setDisplay(display);
|
||||||
}
|
}
|
||||||
|
if (system != null) {
|
||||||
|
res.setSystem(system);
|
||||||
|
}
|
||||||
|
if (version != null) {
|
||||||
|
res.setVersion(version);
|
||||||
|
}
|
||||||
} else if (message != null && !message.equals("No Message returned")) {
|
} else if (message != null && !message.equals("No Message returned")) {
|
||||||
res = new ValidationResult(IssueSeverity.WARNING, message, system, version, new ConceptDefinitionComponent().setDisplay(display).setCode(code), display, null).setTxLink(txLog.getLastId());
|
res = new ValidationResult(IssueSeverity.WARNING, message, system, version, new ConceptDefinitionComponent().setDisplay(display).setCode(code), display, null).setTxLink(txLog.getLastId());
|
||||||
} else if (display != null) {
|
} else if (display != null) {
|
||||||
|
|
|
@ -630,6 +630,9 @@ public class CanonicalResourceManager<T extends CanonicalResource> {
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<T> getSupplements(T cr) {
|
public List<T> getSupplements(T cr) {
|
||||||
|
if (cr == null) {
|
||||||
|
return new ArrayList<T>();
|
||||||
|
}
|
||||||
if (cr.hasSourcePackage()) {
|
if (cr.hasSourcePackage()) {
|
||||||
List<String> pvl = new ArrayList<>();
|
List<String> pvl = new ArrayList<>();
|
||||||
pvl.add(cr.getSourcePackage().getVID());
|
pvl.add(cr.getSourcePackage().getVID());
|
||||||
|
|
|
@ -347,10 +347,11 @@ public class Element extends Base implements NamedItem {
|
||||||
if (children == null)
|
if (children == null)
|
||||||
children = new NamedItemList<Element>();
|
children = new NamedItemList<Element>();
|
||||||
for (Element child : children) {
|
for (Element child : children) {
|
||||||
if (name.equals(child.getName())) {
|
if (nameMatches(child.getName(), name)) {
|
||||||
if (!child.isPrimitive())
|
if (!child.isPrimitive())
|
||||||
throw new Error("Cannot set a value of a non-primitive type ("+name+" on "+this.getName()+")");
|
throw new Error("Cannot set a value of a non-primitive type ("+name+" on "+this.getName()+")");
|
||||||
child.setValue(value.primitiveValue());
|
child.setValue(value.primitiveValue());
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1364,14 +1365,18 @@ public class Element extends Base implements NamedItem {
|
||||||
public Element addElement(String name) {
|
public Element addElement(String name) {
|
||||||
if (children == null)
|
if (children == null)
|
||||||
children = new NamedItemList<Element>();
|
children = new NamedItemList<Element>();
|
||||||
|
int insertionPoint = 0;
|
||||||
|
|
||||||
for (Property p : property.getChildProperties(this.name, type)) {
|
for (Property p : property.getChildProperties(this.name, type)) {
|
||||||
|
while (insertionPoint < children.size() && nameMatches(children.get(insertionPoint).getName(), p.getName())) {
|
||||||
|
insertionPoint++;
|
||||||
|
}
|
||||||
if (p.getName().equals(name)) {
|
if (p.getName().equals(name)) {
|
||||||
if (!p.isList() && hasChild(name, false)) {
|
if (!p.isList() && hasChild(name, false)) {
|
||||||
throw new Error(name+" on "+this.name+" is not a list, so can't add an element");
|
throw new Error(name+" on "+this.name+" is not a list, so can't add an element");
|
||||||
}
|
}
|
||||||
Element ne = new Element(name, p).setFormat(format);
|
Element ne = new Element(name, p).setFormat(format);
|
||||||
children.add(ne);
|
children.add(insertionPoint, ne);
|
||||||
return ne;
|
return ne;
|
||||||
}
|
}
|
||||||
// polymorphic support
|
// polymorphic support
|
||||||
|
@ -1386,7 +1391,7 @@ public class Element extends Base implements NamedItem {
|
||||||
if (p.canBeType(type)) {
|
if (p.canBeType(type)) {
|
||||||
Element ne = new Element(name, p).setFormat(format);
|
Element ne = new Element(name, p).setFormat(format);
|
||||||
ne.setType(type);
|
ne.setType(type);
|
||||||
children.add(ne);
|
children.add(insertionPoint, ne);
|
||||||
return ne;
|
return ne;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1396,6 +1401,15 @@ public class Element extends Base implements NamedItem {
|
||||||
throw new Error("Unrecognised property '"+name+"' on "+this.name);
|
throw new Error("Unrecognised property '"+name+"' on "+this.name);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private boolean nameMatches(String elementName, String propertyName) {
|
||||||
|
if (propertyName.endsWith("[x]")) {
|
||||||
|
String base = propertyName.replace("[x]", "");
|
||||||
|
return elementName.startsWith(base);
|
||||||
|
} else {
|
||||||
|
return elementName.equals(propertyName);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Base copy() {
|
public Base copy() {
|
||||||
Element element = new Element(this);
|
Element element = new Element(this);
|
||||||
|
|
|
@ -419,8 +419,9 @@ public class Property {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (url==null)
|
if (url==null) {
|
||||||
throw new FHIRException("Unable to find type " + t + " for element " + elementName + " with path " + ed.getPath());
|
throw new FHIRException("Unable to find type " + t + " for element " + elementName + " with path " + ed.getPath());
|
||||||
|
}
|
||||||
sd = context.fetchResource(StructureDefinition.class, url);
|
sd = context.fetchResource(StructureDefinition.class, url);
|
||||||
if (sd == null)
|
if (sd == null)
|
||||||
throw new DefinitionException("Unable to find type '"+t+"' for name '"+elementName+"' on property "+definition.getPath());
|
throw new DefinitionException("Unable to find type '"+t+"' for name '"+elementName+"' on property "+definition.getPath());
|
||||||
|
|
|
@ -4659,7 +4659,7 @@ public class FHIRPathEngine {
|
||||||
}
|
}
|
||||||
for (String an : node.getAttributes().keySet()) {
|
for (String an : node.getAttributes().keySet()) {
|
||||||
boolean ok = an.startsWith("xmlns") || Utilities.existsInList(an,
|
boolean ok = an.startsWith("xmlns") || Utilities.existsInList(an,
|
||||||
"title", "style", "class", "id", "idref", "lang", "xml:lang", "dir", "accesskey", "tabindex",
|
"title", "style", "class", "id", "idref", "lang", "xml:lang", "xml:space", "dir", "accesskey", "tabindex",
|
||||||
// tables
|
// tables
|
||||||
"span", "width", "align", "valign", "char", "charoff", "abbr", "axis", "headers", "scope", "rowspan", "colspan") ||
|
"span", "width", "align", "valign", "char", "charoff", "abbr", "axis", "headers", "scope", "rowspan", "colspan") ||
|
||||||
|
|
||||||
|
|
|
@ -157,7 +157,7 @@ public class Base64BinaryType extends PrimitiveType<byte[]> implements IPrimitiv
|
||||||
*/
|
*/
|
||||||
public void checkValidBase64(String toCheck) throws DataFormatException {
|
public void checkValidBase64(String toCheck) throws DataFormatException {
|
||||||
if (!org.hl7.fhir.utilities.Base64.isBase64(toCheck.getBytes())) {
|
if (!org.hl7.fhir.utilities.Base64.isBase64(toCheck.getBytes())) {
|
||||||
throw new DataFormatException("");
|
throw new DataFormatException("Invalid Base64 content: "+toCheck.substring(0, 10)+"...");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -182,6 +182,8 @@ public class BundleRenderer extends ResourceRenderer {
|
||||||
} else {
|
} else {
|
||||||
RendererFactory.factory(subject, context).buildNarrative(status, sec, subject);
|
RendererFactory.factory(subject, context).buildNarrative(status, sec, subject);
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
sec.para().b().tx("Unable to resolve subject '"+displayReference(comp.child("subject"))+"'");
|
||||||
}
|
}
|
||||||
x.hr();
|
x.hr();
|
||||||
sec = docSection(x, "Document Content");
|
sec = docSection(x, "Document Content");
|
||||||
|
@ -212,7 +214,8 @@ public class BundleRenderer extends ResourceRenderer {
|
||||||
}
|
}
|
||||||
if (section.has("text")) {
|
if (section.has("text")) {
|
||||||
ResourceWrapper narrative = section.child("text");
|
ResourceWrapper narrative = section.child("text");
|
||||||
x.addChildren(narrative.getXhtml());
|
ResourceWrapper xh = narrative.child("div");
|
||||||
|
x.addChildren(xh.getXhtml());
|
||||||
}
|
}
|
||||||
if (section.has("section")) {
|
if (section.has("section")) {
|
||||||
List<ResourceWrapper> sections = section.children("section");
|
List<ResourceWrapper> sections = section.children("section");
|
||||||
|
|
|
@ -53,7 +53,8 @@ public class CapabilityStatementRenderer extends ResourceRenderer {
|
||||||
renderResourceTechDetails(r, x);
|
renderResourceTechDetails(r, x);
|
||||||
render(status, x, (CapabilityStatement) r.getBase(), r);
|
render(status, x, (CapabilityStatement) r.getBase(), r);
|
||||||
} else {
|
} else {
|
||||||
throw new Error("CapabilityStatementRenderer only renders native resources directly");
|
// the intention is to change this in the future
|
||||||
|
x.para().tx("CapabilityStatementRenderer only renders native resources directly");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -422,7 +423,7 @@ public class CapabilityStatementRenderer extends ResourceRenderer {
|
||||||
private void addSupportedCSs(RenderingStatus status, XhtmlNode x, CapabilityStatement cap, ResourceWrapper res) throws UnsupportedEncodingException, IOException {
|
private void addSupportedCSs(RenderingStatus status, XhtmlNode x, CapabilityStatement cap, ResourceWrapper res) throws UnsupportedEncodingException, IOException {
|
||||||
if (cap.hasInstantiates()) {
|
if (cap.hasInstantiates()) {
|
||||||
XhtmlNode p = x.para();
|
XhtmlNode p = x.para();
|
||||||
p.tx(cap.getInstantiates().size() > 1 ? "This CapabilityStatement instantiates these CapabilityStatements" : "This CapabilityStatement instantiates the CapabilityStatement");
|
p.tx(cap.getInstantiates().size() > 1 ? "This CapabilityStatement instantiates these CapabilityStatements " : "This CapabilityStatement instantiates the CapabilityStatement ");
|
||||||
boolean first = true;
|
boolean first = true;
|
||||||
for (CanonicalType ct : cap.getInstantiates()) {
|
for (CanonicalType ct : cap.getInstantiates()) {
|
||||||
if (first) {first = false;} else {p.tx(", ");};
|
if (first) {first = false;} else {p.tx(", ");};
|
||||||
|
@ -431,7 +432,7 @@ public class CapabilityStatementRenderer extends ResourceRenderer {
|
||||||
}
|
}
|
||||||
if (cap.hasImports()) {
|
if (cap.hasImports()) {
|
||||||
XhtmlNode p = x.para();
|
XhtmlNode p = x.para();
|
||||||
p.tx(cap.getImports().size() > 1 ? "This CapabilityStatement imports these CapabilityStatements" : "This CapabilityStatement imports the CapabilityStatement");
|
p.tx(cap.getImports().size() > 1 ? "This CapabilityStatement imports these CapabilityStatements " : "This CapabilityStatement imports the CapabilityStatement ");
|
||||||
boolean first = true;
|
boolean first = true;
|
||||||
for (CanonicalType ct : cap.getImports()) {
|
for (CanonicalType ct : cap.getImports()) {
|
||||||
if (first) {first = false;} else {p.tx(", ");};
|
if (first) {first = false;} else {p.tx(", ");};
|
||||||
|
|
|
@ -53,7 +53,8 @@ public class CodeSystemRenderer extends TerminologyRenderer {
|
||||||
genSummaryTable(status, x, (CodeSystem) r.getBase());
|
genSummaryTable(status, x, (CodeSystem) r.getBase());
|
||||||
render(status, x, (CodeSystem) r.getBase(), r);
|
render(status, x, (CodeSystem) r.getBase(), r);
|
||||||
} else {
|
} else {
|
||||||
throw new Error("CodeSystemRenderer only renders native resources directly");
|
// the intention is to change this in the future
|
||||||
|
x.para().tx("CodeSystemRenderer only renders native resources directly");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -29,7 +29,8 @@ public class CompartmentDefinitionRenderer extends ResourceRenderer {
|
||||||
genSummaryTable(status, x, (CompartmentDefinition) r.getBase());
|
genSummaryTable(status, x, (CompartmentDefinition) r.getBase());
|
||||||
render(status, x, (CompartmentDefinition) r.getBase());
|
render(status, x, (CompartmentDefinition) r.getBase());
|
||||||
} else {
|
} else {
|
||||||
throw new Error("CompartmentDefinitionRenderer only renders native resources directly");
|
// it seems very inlikely this will change
|
||||||
|
x.para().tx("CompartmentDefinitionRenderer only renders native resources directly");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -49,7 +49,8 @@ public class ConceptMapRenderer extends TerminologyRenderer {
|
||||||
genSummaryTable(status, x, (ConceptMap) r.getBase());
|
genSummaryTable(status, x, (ConceptMap) r.getBase());
|
||||||
render(status, r, x, (ConceptMap) r.getBase(), false);
|
render(status, r, x, (ConceptMap) r.getBase(), false);
|
||||||
} else {
|
} else {
|
||||||
throw new Error("ConceptMapRenderer only renders native resources directly");
|
// the intention is to change this in the future
|
||||||
|
x.para().tx("ConceptMapRenderer only renders native resources directly");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1841,7 +1841,7 @@ public class DataRenderer extends Renderer implements CodeResolver {
|
||||||
else
|
else
|
||||||
x.tx("?");
|
x.tx("?");
|
||||||
if (q.has("low") && q.child("low").has("unit"))
|
if (q.has("low") && q.child("low").has("unit"))
|
||||||
x.tx(" "+q.child("low").child("unit"));
|
x.tx(" "+q.child("low").primitiveValue("unit"));
|
||||||
}
|
}
|
||||||
|
|
||||||
public String displayPeriod(ResourceWrapper p) {
|
public String displayPeriod(ResourceWrapper p) {
|
||||||
|
|
|
@ -149,13 +149,13 @@ public class DiagnosticReportRenderer extends ResourceRenderer {
|
||||||
if (r == null)
|
if (r == null)
|
||||||
container.tx(context.formatPhrase(RenderingContext.DIAG_REP_REND_UNABLE));
|
container.tx(context.formatPhrase(RenderingContext.DIAG_REP_REND_UNABLE));
|
||||||
else if (r.getResource().fhirType().equals("Patient"))
|
else if (r.getResource().fhirType().equals("Patient"))
|
||||||
generatePatientSummary(container, r.getResource());
|
generatePatientSummary(status, container, r.getResource());
|
||||||
else
|
else
|
||||||
container.tx(context.formatPhrase(RenderingContext.GENERAL_TODO));
|
container.tx(context.formatPhrase(RenderingContext.GENERAL_TODO));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void generatePatientSummary(XhtmlNode c, ResourceWrapper r) throws FHIRFormatError, DefinitionException, FHIRException, IOException, EOperationOutcome {
|
private void generatePatientSummary(RenderingStatus status, XhtmlNode c, ResourceWrapper r) throws FHIRFormatError, DefinitionException, FHIRException, IOException, EOperationOutcome {
|
||||||
new PatientRenderer(context).describe(c, r);
|
new PatientRenderer(context).buildSummary(status, c, r);
|
||||||
}
|
}
|
||||||
|
|
||||||
private List<ObservationNode> fetchObservations(List<ResourceWrapper> list) throws UnsupportedEncodingException, FHIRException, IOException {
|
private List<ObservationNode> fetchObservations(List<ResourceWrapper> list) throws UnsupportedEncodingException, FHIRException, IOException {
|
||||||
|
|
|
@ -50,7 +50,8 @@ public class ExampleScenarioRenderer extends TerminologyRenderer {
|
||||||
genSummaryTable(status, x, (ExampleScenario) r.getBase());
|
genSummaryTable(status, x, (ExampleScenario) r.getBase());
|
||||||
render(status, x, (ExampleScenario) r.getBase(), r);
|
render(status, x, (ExampleScenario) r.getBase(), r);
|
||||||
} else {
|
} else {
|
||||||
throw new Error("ExampleScenarioRenderer only renders native resources directly");
|
// the intention is to change this in the future
|
||||||
|
x.para().tx("ExampleScenarioRenderer only renders native resources directly");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -25,7 +25,8 @@ public class ImplementationGuideRenderer extends ResourceRenderer {
|
||||||
genSummaryTable(status, x, (ImplementationGuide) r.getBase());
|
genSummaryTable(status, x, (ImplementationGuide) r.getBase());
|
||||||
render(status, x, (ImplementationGuide) r.getBase());
|
render(status, x, (ImplementationGuide) r.getBase());
|
||||||
} else {
|
} else {
|
||||||
throw new Error("ImplementationGuideRenderer only renders native resources directly");
|
// the intention is to change this in the future
|
||||||
|
x.para().tx("ImplementationGuideRenderer only renders native resources directly");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -29,7 +29,8 @@ public class NamingSystemRenderer extends ResourceRenderer {
|
||||||
genSummaryTable(status, x, (NamingSystem) r.getBase());
|
genSummaryTable(status, x, (NamingSystem) r.getBase());
|
||||||
render(status, x, (NamingSystem) r.getBase());
|
render(status, x, (NamingSystem) r.getBase());
|
||||||
} else {
|
} else {
|
||||||
throw new Error("NamingSystemRenderer only renders native resources directly");
|
// the intention is to change this in the future
|
||||||
|
x.para().tx("NamingSystemRenderer only renders native resources directly");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -40,7 +40,8 @@ public class OperationDefinitionRenderer extends TerminologyRenderer {
|
||||||
genSummaryTable(status, x, (OperationDefinition) r.getBase());
|
genSummaryTable(status, x, (OperationDefinition) r.getBase());
|
||||||
render(status, x, (OperationDefinition) r.getBase());
|
render(status, x, (OperationDefinition) r.getBase());
|
||||||
} else {
|
} else {
|
||||||
throw new Error("OperationDefinitionRenderer only renders native resources directly");
|
// the intention is to change this in the future
|
||||||
|
x.para().tx("OperationDefinitionRenderer only renders native resources directly");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -126,14 +126,13 @@ public class QuestionnaireRenderer extends TerminologyRenderer {
|
||||||
|
|
||||||
private void renderOptions(List<ResourceWrapper> items, XhtmlNode x) {
|
private void renderOptions(List<ResourceWrapper> items, XhtmlNode x) {
|
||||||
for (ResourceWrapper i : items) {
|
for (ResourceWrapper i : items) {
|
||||||
renderItemOptions(x, i);
|
renderItemOptionsList(x, i);
|
||||||
renderOptions(i.children("item"), x);
|
renderOptions(i.children("item"), x);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void renderItemOptions(XhtmlNode x, ResourceWrapper i) {
|
public void renderItemOptions(XhtmlNode x, ResourceWrapper i) {
|
||||||
if (i.has("answerOption")) {
|
if (i.has("answerOption")) {
|
||||||
assert x.getName().equals("select");
|
|
||||||
for (ResourceWrapper opt : i.children("answerOption")) {
|
for (ResourceWrapper opt : i.children("answerOption")) {
|
||||||
String value = "??";
|
String value = "??";
|
||||||
String text = "??";
|
String text = "??";
|
||||||
|
@ -157,6 +156,35 @@ public class QuestionnaireRenderer extends TerminologyRenderer {
|
||||||
x.option(value, text, selected);
|
x.option(value, text, selected);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void renderItemOptionsList(XhtmlNode x, ResourceWrapper i) {
|
||||||
|
if (i.has("answerOption")) {
|
||||||
|
x.an(context.prefixAnchor("opt-item."+i.primitiveValue("linkId")));
|
||||||
|
x.para().b().tx(context.formatPhrase(RenderingContext.QUEST_ANSW, i.primitiveValue("linkId"))+" ");
|
||||||
|
XhtmlNode ul = x.ul();
|
||||||
|
for (ResourceWrapper opt : i.children("answerOption")) {
|
||||||
|
XhtmlNode li = ul.li();
|
||||||
|
li.style("font-size: 11px");
|
||||||
|
ResourceWrapper v = opt.child("value");
|
||||||
|
if (v.isPrimitive()) {
|
||||||
|
li.tx(v.primitiveValue());
|
||||||
|
} else if (v.fhirType().equals("Coding")) {
|
||||||
|
String link = v.has("system") ? new ContextUtilities(context.getWorker()).getLinkForUrl(context.getLink(KnownLinkType.SPEC), v.primitiveValue("system")) : null;
|
||||||
|
if (link == null) {
|
||||||
|
li.tx(v.primitiveValue("system")+"#"+v.primitiveValue("code"));
|
||||||
|
} else {
|
||||||
|
li.ah(link).tx(displaySystem(v.primitiveValue("system")));
|
||||||
|
li.tx(": "+v.primitiveValue("code"));
|
||||||
|
}
|
||||||
|
if (v.has("display")) {
|
||||||
|
li.tx(" (\""+v.primitiveValue("display")+"\")");
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
li.tx("??");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean hasAnyOptions(List<ResourceWrapper> items) {
|
private boolean hasAnyOptions(List<ResourceWrapper> items) {
|
||||||
|
|
|
@ -150,6 +150,9 @@ public abstract class ResourceRenderer extends DataRenderer {
|
||||||
public abstract void buildNarrative(RenderingStatus status, XhtmlNode x, ResourceWrapper r) throws FHIRFormatError, DefinitionException, IOException, FHIRException, EOperationOutcome;
|
public abstract void buildNarrative(RenderingStatus status, XhtmlNode x, ResourceWrapper r) throws FHIRFormatError, DefinitionException, IOException, FHIRException, EOperationOutcome;
|
||||||
public abstract String buildSummary(ResourceWrapper r) throws UnsupportedEncodingException, IOException;
|
public abstract String buildSummary(ResourceWrapper r) throws UnsupportedEncodingException, IOException;
|
||||||
|
|
||||||
|
public void buildSummary(RenderingStatus status, XhtmlNode x, ResourceWrapper r) throws UnsupportedEncodingException, IOException {
|
||||||
|
x.tx(buildSummary(r));
|
||||||
|
}
|
||||||
|
|
||||||
public String canonicalTitle(ResourceWrapper r) {
|
public String canonicalTitle(ResourceWrapper r) {
|
||||||
if (r.has("title")) {
|
if (r.has("title")) {
|
||||||
|
@ -870,7 +873,7 @@ public abstract class ResourceRenderer extends DataRenderer {
|
||||||
boolean sfirst = true;
|
boolean sfirst = true;
|
||||||
p = plateStyle(div.para());
|
p = plateStyle(div.para());
|
||||||
if (versionId != null) {
|
if (versionId != null) {
|
||||||
p.tx(context.formatPhrase(RenderingContext.RES_REND_VER, versionId));
|
p.tx(context.formatPhrase(RenderingContext.RES_REND_VER, versionId.primitiveValue()));
|
||||||
sfirst = false;
|
sfirst = false;
|
||||||
}
|
}
|
||||||
if (lastUpdated != null) {
|
if (lastUpdated != null) {
|
||||||
|
|
|
@ -41,7 +41,8 @@ public class SearchParameterRenderer extends TerminologyRenderer {
|
||||||
|
|
||||||
render(status, x, (SearchParameter) r.getBase());
|
render(status, x, (SearchParameter) r.getBase());
|
||||||
} else {
|
} else {
|
||||||
throw new Error("SearchParameterRenderer only renders native resources directly");
|
// the intention is to change this in the future
|
||||||
|
x.para().tx("SearchParameterRenderer only renders native resources directly");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -103,18 +103,20 @@ public class StructureDefinitionRenderer extends ResourceRenderer {
|
||||||
@Override
|
@Override
|
||||||
public void buildNarrative(RenderingStatus status, XhtmlNode x, ResourceWrapper r) throws FHIRFormatError, DefinitionException, IOException, FHIRException, EOperationOutcome {
|
public void buildNarrative(RenderingStatus status, XhtmlNode x, ResourceWrapper r) throws FHIRFormatError, DefinitionException, IOException, FHIRException, EOperationOutcome {
|
||||||
if (!r.isDirect()) {
|
if (!r.isDirect()) {
|
||||||
throw new Error("StructureDefinitionRenderer only renders native resources directly");
|
// it seems very unlikely that this will change in the future
|
||||||
}
|
x.para().tx("StructureDefinitionRenderer only renders native resources directly");
|
||||||
renderResourceTechDetails(r, x);
|
} else {
|
||||||
StructureDefinition sd = (StructureDefinition) r.getBase();
|
renderResourceTechDetails(r, x);
|
||||||
genSummaryTable(status, x, sd);
|
StructureDefinition sd = (StructureDefinition) r.getBase();
|
||||||
if (context.getStructureMode() == StructureDefinitionRendererMode.DATA_DICT) {
|
genSummaryTable(status, x, sd);
|
||||||
renderDict(status, sd, sd.getDifferential().getElement(), x.table("dict"), false, GEN_MODE_DIFF, "", r);
|
if (context.getStructureMode() == StructureDefinitionRendererMode.DATA_DICT) {
|
||||||
} else {
|
renderDict(status, sd, sd.getDifferential().getElement(), x.table("dict"), false, GEN_MODE_DIFF, "", r);
|
||||||
x.addChildNode(generateTable(status, context.getDefinitionsTarget(), sd, true, context.getDestDir(), false, sd.getId(), false,
|
} else {
|
||||||
context.getLink(KnownLinkType.SPEC), "", sd.getKind() == StructureDefinitionKind.LOGICAL, false, null, false, context.withUniqueLocalPrefix(null), "r", r));
|
x.addChildNode(generateTable(status, context.getDefinitionsTarget(), sd, true, context.getDestDir(), false, sd.getId(), false,
|
||||||
}
|
context.getLink(KnownLinkType.SPEC), "", sd.getKind() == StructureDefinitionKind.LOGICAL, false, null, false, context.withUniqueLocalPrefix(null), "r", r));
|
||||||
status.setExtensions(true);
|
}
|
||||||
|
status.setExtensions(true);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -57,7 +57,8 @@ public class StructureMapRenderer extends TerminologyRenderer {
|
||||||
genSummaryTable(status, x, (StructureMap) r.getBase());
|
genSummaryTable(status, x, (StructureMap) r.getBase());
|
||||||
renderMap(status, x.pre("fml"), (StructureMap) r.getBase());
|
renderMap(status, x.pre("fml"), (StructureMap) r.getBase());
|
||||||
} else {
|
} else {
|
||||||
throw new Error("StructureMapRenderer only renders native resources directly");
|
// the intention is to change this in the future
|
||||||
|
x.para().tx("StructureMapRenderer only renders native resources directly");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -73,21 +73,23 @@ public class ValueSetRenderer extends TerminologyRenderer {
|
||||||
@Override
|
@Override
|
||||||
public void buildNarrative(RenderingStatus status, XhtmlNode x, ResourceWrapper r) throws FHIRFormatError, DefinitionException, IOException, FHIRException, EOperationOutcome {
|
public void buildNarrative(RenderingStatus status, XhtmlNode x, ResourceWrapper r) throws FHIRFormatError, DefinitionException, IOException, FHIRException, EOperationOutcome {
|
||||||
if (!r.isDirect()) {
|
if (!r.isDirect()) {
|
||||||
throw new Error("ValueSetRenderer only renders native resources directly");
|
// the intention is to change this in the future
|
||||||
}
|
x.para().tx("ValueSetRenderer only renders native resources directly");
|
||||||
renderResourceTechDetails(r, x);
|
|
||||||
ValueSet vs = (ValueSet) r.getBase();
|
|
||||||
genSummaryTable(status, x, vs);
|
|
||||||
List<UsedConceptMap> maps = findReleventMaps(vs);
|
|
||||||
|
|
||||||
if (vs.hasExpansion()) {
|
|
||||||
// for now, we just accept an expansion if there is one
|
|
||||||
generateExpansion(status, r, x, vs, false, maps);
|
|
||||||
} else {
|
} else {
|
||||||
generateComposition(status, r, x, vs, false, maps);
|
renderResourceTechDetails(r, x);
|
||||||
|
ValueSet vs = (ValueSet) r.getBase();
|
||||||
|
genSummaryTable(status, x, vs);
|
||||||
|
List<UsedConceptMap> maps = findReleventMaps(vs);
|
||||||
|
|
||||||
|
if (vs.hasExpansion()) {
|
||||||
|
// for now, we just accept an expansion if there is one
|
||||||
|
generateExpansion(status, r, x, vs, false, maps);
|
||||||
|
} else {
|
||||||
|
generateComposition(status, r, x, vs, false, maps);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String buildSummary(ResourceWrapper r) throws UnsupportedEncodingException, IOException {
|
public String buildSummary(ResourceWrapper r) throws UnsupportedEncodingException, IOException {
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
package org.hl7.fhir.r5.terminologies.utilities;
|
package org.hl7.fhir.r5.terminologies.utilities;
|
||||||
|
|
||||||
public enum TerminologyServiceErrorClass {
|
public enum TerminologyServiceErrorClass {
|
||||||
UNKNOWN, NOSERVICE, SERVER_ERROR, VALUESET_UNSUPPORTED, CODESYSTEM_UNSUPPORTED, BLOCKED_BY_OPTIONS, INTERNAL_ERROR, BUSINESS_RULE, TOO_COSTLY, PROCESSING;
|
UNKNOWN, NOSERVICE, SERVER_ERROR, VALUESET_UNSUPPORTED, CODESYSTEM_UNSUPPORTED, CODESYSTEM_UNSUPPORTED_VERSION, BLOCKED_BY_OPTIONS, INTERNAL_ERROR, BUSINESS_RULE, TOO_COSTLY, PROCESSING;
|
||||||
|
|
||||||
public boolean isInfrastructure() {
|
public boolean isInfrastructure() {
|
||||||
return this == NOSERVICE || this == SERVER_ERROR || this == VALUESET_UNSUPPORTED;
|
return this == NOSERVICE || this == SERVER_ERROR || this == VALUESET_UNSUPPORTED;
|
||||||
|
|
|
@ -11,6 +11,7 @@ import org.hl7.fhir.r5.model.ContactDetail;
|
||||||
import org.hl7.fhir.r5.model.ContactPoint;
|
import org.hl7.fhir.r5.model.ContactPoint;
|
||||||
import org.hl7.fhir.r5.model.ContactPoint.ContactPointSystem;
|
import org.hl7.fhir.r5.model.ContactPoint.ContactPointSystem;
|
||||||
import org.hl7.fhir.utilities.HL7WorkGroups;
|
import org.hl7.fhir.utilities.HL7WorkGroups;
|
||||||
|
import org.hl7.fhir.utilities.Utilities;
|
||||||
import org.hl7.fhir.utilities.VersionUtilities;
|
import org.hl7.fhir.utilities.VersionUtilities;
|
||||||
import org.hl7.fhir.utilities.xml.XMLUtil;
|
import org.hl7.fhir.utilities.xml.XMLUtil;
|
||||||
|
|
||||||
|
@ -71,16 +72,18 @@ public class CanonicalResourceUtilities {
|
||||||
if (ext == null) {
|
if (ext == null) {
|
||||||
ext = res.addElement("extension");
|
ext = res.addElement("extension");
|
||||||
ext.setChildValue("url", ToolingExtensions.EXT_WORKGROUP);
|
ext.setChildValue("url", ToolingExtensions.EXT_WORKGROUP);
|
||||||
|
}
|
||||||
|
ext.setChildValue("value[x]", new CodeType(code));
|
||||||
|
if (!Utilities.existsInList(res.fhirType(), "ClinicalUseDefinition")) {
|
||||||
|
res.setChildValue("publisher", "HL7 International / "+wg.getName());
|
||||||
|
while (res.hasChildren("contact")) {
|
||||||
|
res.removeChild("contact");
|
||||||
|
}
|
||||||
|
Element c = res.addElement("contact");
|
||||||
|
Element t = c.addElement("telecom");
|
||||||
|
t.setChildValue("system", "url");
|
||||||
|
t.setChildValue("value", wg.getLink());
|
||||||
}
|
}
|
||||||
ext.setChildValue("valueCode", new CodeType(code));
|
|
||||||
res.setChildValue("publisher", "HL7 International / "+wg.getName());
|
|
||||||
while (res.hasChildren("contact")) {
|
|
||||||
res.removeChild("contact");
|
|
||||||
}
|
|
||||||
Element c = res.addElement("contact");
|
|
||||||
Element t = c.addElement("telecom");
|
|
||||||
t.setChildValue("system", "url");
|
|
||||||
t.setChildValue("value", wg.getLink());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//
|
//
|
||||||
|
|
|
@ -233,7 +233,7 @@ public class NarrativeGenerationTests {
|
||||||
@ParameterizedTest(name = "{index}: file {0}")
|
@ParameterizedTest(name = "{index}: file {0}")
|
||||||
@MethodSource("data")
|
@MethodSource("data")
|
||||||
public void test(String id, TestDetails test) throws Exception {
|
public void test(String id, TestDetails test) throws Exception {
|
||||||
XhtmlNode.setCheckPara(true);
|
XhtmlNode.setCheckParaGeneral(true);
|
||||||
if (test.getRegister() != null) {
|
if (test.getRegister() != null) {
|
||||||
if (test.getRegister().endsWith(".json")) {
|
if (test.getRegister().endsWith(".json")) {
|
||||||
context.cacheResource(new JsonParser().parse(TestingUtilities.loadTestResourceStream("r5", "narrative", test.getRegister())));
|
context.cacheResource(new JsonParser().parse(TestingUtilities.loadTestResourceStream("r5", "narrative", test.getRegister())));
|
||||||
|
|
|
@ -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>6.3.19-SNAPSHOT</version>
|
<version>6.3.20-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>6.3.19-SNAPSHOT</version>
|
<version>6.3.20-SNAPSHOT</version>
|
||||||
<relativePath>../pom.xml</relativePath>
|
<relativePath>../pom.xml</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
|
|
@ -157,6 +157,7 @@ public class I18nConstants {
|
||||||
public static final String CONCEPTMAP_SHAREABLE_MISSING = "CONCEPTMAP_SHAREABLE_MISSING";
|
public static final String CONCEPTMAP_SHAREABLE_MISSING = "CONCEPTMAP_SHAREABLE_MISSING";
|
||||||
public static final String CONCEPTMAP_SHAREABLE_MISSING_HL7 = "CONCEPTMAP_SHAREABLE_MISSING_HL7";
|
public static final String CONCEPTMAP_SHAREABLE_MISSING_HL7 = "CONCEPTMAP_SHAREABLE_MISSING_HL7";
|
||||||
public static final String CONCEPTMAP_VS_CONCEPT_CODE_UNKNOWN_SYSTEM = "CONCEPTMAP_VS_CONCEPT_CODE_UNKNOWN_SYSTEM";
|
public static final String CONCEPTMAP_VS_CONCEPT_CODE_UNKNOWN_SYSTEM = "CONCEPTMAP_VS_CONCEPT_CODE_UNKNOWN_SYSTEM";
|
||||||
|
public static final String CONCEPTMAP_VS_CONCEPT_CODE_UNKNOWN_SYSTEM_VERSION = "CONCEPTMAP_VS_CONCEPT_CODE_UNKNOWN_SYSTEM_VERSION";
|
||||||
public static final String CONCEPTMAP_VS_INVALID_CONCEPT_CODE = "CONCEPTMAP_VS_INVALID_CONCEPT_CODE";
|
public static final String CONCEPTMAP_VS_INVALID_CONCEPT_CODE = "CONCEPTMAP_VS_INVALID_CONCEPT_CODE";
|
||||||
public static final String CONCEPTMAP_VS_INVALID_CONCEPT_CODE_VER = "CONCEPTMAP_VS_INVALID_CONCEPT_CODE_VER";
|
public static final String CONCEPTMAP_VS_INVALID_CONCEPT_CODE_VER = "CONCEPTMAP_VS_INVALID_CONCEPT_CODE_VER";
|
||||||
public static final String CONCEPTMAP_VS_TOO_MANY_CODES = "CONCEPTMAP_VS_TOO_MANY_CODES";
|
public static final String CONCEPTMAP_VS_TOO_MANY_CODES = "CONCEPTMAP_VS_TOO_MANY_CODES";
|
||||||
|
@ -1102,4 +1103,6 @@ public class I18nConstants {
|
||||||
public static final String TYPE_SPECIFIC_CHECKS_DT_XHTML_ACTIVE_HREF = "TYPE_SPECIFIC_CHECKS_DT_XHTML_ACTIVE_HREF";
|
public static final String TYPE_SPECIFIC_CHECKS_DT_XHTML_ACTIVE_HREF = "TYPE_SPECIFIC_CHECKS_DT_XHTML_ACTIVE_HREF";
|
||||||
public static final String TYPE_SPECIFIC_CHECKS_DT_XHTML_UNKNOWN_HREF = "TYPE_SPECIFIC_CHECKS_DT_XHTML_UNKNOWN_HREF";
|
public static final String TYPE_SPECIFIC_CHECKS_DT_XHTML_UNKNOWN_HREF = "TYPE_SPECIFIC_CHECKS_DT_XHTML_UNKNOWN_HREF";
|
||||||
public static final String TYPE_SPECIFIC_CHECKS_DT_XHTML_LITERAL_HREF = "TYPE_SPECIFIC_CHECKS_DT_XHTML_LITERAL_HREF";
|
public static final String TYPE_SPECIFIC_CHECKS_DT_XHTML_LITERAL_HREF = "TYPE_SPECIFIC_CHECKS_DT_XHTML_LITERAL_HREF";
|
||||||
|
public static final String SM_TARGET_TYPE_UNKNOWN = "SM_TARGET_TYPE_UNKNOWN";
|
||||||
|
public static final String XHTML_XHTML_ATTRIBUTE_XML_SPACE = "XHTML_XHTML_ATTRIBUTE_XML_SPACE";
|
||||||
}
|
}
|
||||||
|
|
|
@ -72,7 +72,9 @@ public class XhtmlNode extends XhtmlFluent implements IBaseXhtml {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static boolean checkPara = false;
|
private static boolean checkParaGeneral = false;
|
||||||
|
private boolean checkParaTree = false;
|
||||||
|
|
||||||
public static final String NBSP = Character.toString((char)0xa0);
|
public static final String NBSP = Character.toString((char)0xa0);
|
||||||
public static final String XMLNS = "http://www.w3.org/1999/xhtml";
|
public static final String XMLNS = "http://www.w3.org/1999/xhtml";
|
||||||
private static final String DECL_XMLNS = " xmlns=\""+XMLNS+"\"";
|
private static final String DECL_XMLNS = " xmlns=\""+XMLNS+"\"";
|
||||||
|
@ -91,6 +93,7 @@ public class XhtmlNode extends XhtmlFluent implements IBaseXhtml {
|
||||||
|
|
||||||
public XhtmlNode() {
|
public XhtmlNode() {
|
||||||
super();
|
super();
|
||||||
|
checkParaTree = checkParaGeneral;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -119,7 +122,7 @@ public class XhtmlNode extends XhtmlFluent implements IBaseXhtml {
|
||||||
|
|
||||||
public XhtmlNode setName(String name) {
|
public XhtmlNode setName(String name) {
|
||||||
assert name.contains(":") == false : "Name should not contain any : but was " + name;
|
assert name.contains(":") == false : "Name should not contain any : but was " + name;
|
||||||
if (checkPara && "p".equals(name)) {
|
if (checkParaTree && "p".equals(name)) {
|
||||||
isInPara = true;
|
isInPara = true;
|
||||||
}
|
}
|
||||||
this.name = name;
|
this.name = name;
|
||||||
|
@ -1160,7 +1163,8 @@ public class XhtmlNode extends XhtmlFluent implements IBaseXhtml {
|
||||||
|
|
||||||
|
|
||||||
private void checkWhenAddingNode(XhtmlNode node) {
|
private void checkWhenAddingNode(XhtmlNode node) {
|
||||||
if (checkPara) {
|
node.checkParaTree = checkParaTree;
|
||||||
|
if (checkParaTree) {
|
||||||
if (isInPara) {
|
if (isInPara) {
|
||||||
if (Utilities.existsInList(node.name, "div", "blockquote", "table", "ol", "ul", "p")) {
|
if (Utilities.existsInList(node.name, "div", "blockquote", "table", "ol", "ul", "p")) {
|
||||||
throw new Error("Error: attempt to add "+node.name+" inside an html paragraph");
|
throw new Error("Error: attempt to add "+node.name+" inside an html paragraph");
|
||||||
|
@ -1176,13 +1180,23 @@ public class XhtmlNode extends XhtmlFluent implements IBaseXhtml {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public static boolean isCheckPara() {
|
public static boolean isCheckParaGeneral() {
|
||||||
return checkPara;
|
return checkParaGeneral;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public static void setCheckPara(boolean checkPara) {
|
public static void setCheckParaGeneral(boolean checkParaGeneral) {
|
||||||
XhtmlNode.checkPara = checkPara;
|
XhtmlNode.checkParaGeneral = checkParaGeneral;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public boolean isCheckParaTree() {
|
||||||
|
return checkParaTree;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public void setCheckParaTree(boolean checkParaTree) {
|
||||||
|
this.checkParaTree = checkParaTree;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -500,6 +500,7 @@ public class XhtmlParser {
|
||||||
if ((entryName != null) && !n.getName().equals(entryName))
|
if ((entryName != null) && !n.getName().equals(entryName))
|
||||||
throw new FHIRFormatError("Unable to Parse HTML - starts with '"+n+"' not '"+entryName+"'"+descLoc());
|
throw new FHIRFormatError("Unable to Parse HTML - starts with '"+n+"' not '"+entryName+"'"+descLoc());
|
||||||
XhtmlNode root = result.addTag(n.getName());
|
XhtmlNode root = result.addTag(n.getName());
|
||||||
|
root.setCheckParaTree(false);
|
||||||
root.setLocation(markLocation());
|
root.setLocation(markLocation());
|
||||||
parseAttributes(root);
|
parseAttributes(root);
|
||||||
markLocation();
|
markLocation();
|
||||||
|
|
|
@ -545,6 +545,14 @@ public class XMLUtil {
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static Element addChild(Document doc, Element element, String name, String namespace, int indent) {
|
||||||
|
Node node = doc.createTextNode("\n"+Utilities.padLeft("", ' ', indent));
|
||||||
|
Element child = doc.createElementNS(namespace, name);
|
||||||
|
element.appendChild(child);
|
||||||
|
element.appendChild(node);
|
||||||
|
return child;
|
||||||
|
}
|
||||||
|
|
||||||
public static Element insertChild(Document doc, Element element, String name, String namespace, int indent) {
|
public static Element insertChild(Document doc, Element element, String name, String namespace, int indent) {
|
||||||
Node node = doc.createTextNode("\n"+Utilities.padLeft("", ' ', indent));
|
Node node = doc.createTextNode("\n"+Utilities.padLeft("", ' ', indent));
|
||||||
Element child = doc.createElementNS(namespace, name);
|
Element child = doc.createElementNS(namespace, name);
|
||||||
|
|
|
@ -1107,6 +1107,7 @@ xml_attr_value_invalid = The XML Attribute {0} has an invalid character
|
||||||
xml_encoding_invalid = The XML encoding is invalid (must be UTF-8)
|
xml_encoding_invalid = The XML encoding is invalid (must be UTF-8)
|
||||||
Bundle_BUNDLE_Entry_NotFound = Can''t find ''{0}'' in the bundle ({1})
|
Bundle_BUNDLE_Entry_NotFound = Can''t find ''{0}'' in the bundle ({1})
|
||||||
CONCEPTMAP_VS_CONCEPT_CODE_UNKNOWN_SYSTEM = The code ''{1}'' comes from the system {0} which could not be found, so it''s not known whether it''s valid in the value set ''{2}''
|
CONCEPTMAP_VS_CONCEPT_CODE_UNKNOWN_SYSTEM = The code ''{1}'' comes from the system {0} which could not be found, so it''s not known whether it''s valid in the value set ''{2}''
|
||||||
|
CONCEPTMAP_VS_CONCEPT_CODE_UNKNOWN_SYSTEM_VERSION = The code ''{1}'' comes from the system {0} version {3} which could not be found, so it''s not known whether it''s valid in the value set ''{2}''
|
||||||
SD_TYPE_PARAMETER_MISSING = The type definition ''{2}'' does not declare a type parameter, but it is derived from the type definition ''{0}'' which has the type parameter ''{1}''
|
SD_TYPE_PARAMETER_MISSING = The type definition ''{2}'' does not declare a type parameter, but it is derived from the type definition ''{0}'' which has the type parameter ''{1}''
|
||||||
SD_TYPE_PARAMETER_UNKNOWN = The type definition ''{0}'' has the type parameter ''{1}'' but it is not a known type so derivation consistency cannot be checked
|
SD_TYPE_PARAMETER_UNKNOWN = The type definition ''{0}'' has the type parameter ''{1}'' but it is not a known type so derivation consistency cannot be checked
|
||||||
SD_TYPE_PARAMETER_INVALID = The type definition ''{2}'' has a type parameter ''{3}'', which is not consistent with it''s ancestor type definition ''{0}'' which has the type parameter ''{1}''
|
SD_TYPE_PARAMETER_INVALID = The type definition ''{2}'' has a type parameter ''{3}'', which is not consistent with it''s ancestor type definition ''{0}'' which has the type parameter ''{1}''
|
||||||
|
@ -1130,3 +1131,6 @@ TYPE_SPECIFIC_CHECKS_DT_XHTML_EMPTY_HREF = Hyperlink at ''{0}'' for ''{1}'' is e
|
||||||
TYPE_SPECIFIC_CHECKS_DT_XHTML_ACTIVE_HREF = Hyperlink scheme ''{3}'' in ''{0}'' at ''{1}'' for ''{2}'' has active content, which is a security risk and not allowed
|
TYPE_SPECIFIC_CHECKS_DT_XHTML_ACTIVE_HREF = Hyperlink scheme ''{3}'' in ''{0}'' at ''{1}'' for ''{2}'' has active content, which is a security risk and not allowed
|
||||||
TYPE_SPECIFIC_CHECKS_DT_XHTML_UNKNOWN_HREF = Hyperlink scheme ''{3}'' in ''{0}'' at ''{1}'' for ''{2}'' is not a widely supported protocol and should be checked
|
TYPE_SPECIFIC_CHECKS_DT_XHTML_UNKNOWN_HREF = Hyperlink scheme ''{3}'' in ''{0}'' at ''{1}'' for ''{2}'' is not a widely supported protocol and should be checked
|
||||||
TYPE_SPECIFIC_CHECKS_DT_XHTML_LITERAL_HREF = Hyperlink scheme ''{3}'' in ''{0}'' at ''{1}'' for ''{2}'' is not a valid hyperlinkable scheme
|
TYPE_SPECIFIC_CHECKS_DT_XHTML_LITERAL_HREF = Hyperlink scheme ''{3}'' in ''{0}'' at ''{1}'' for ''{2}'' is not a valid hyperlinkable scheme
|
||||||
|
SM_TARGET_TYPE_UNKNOWN = The type of the target variable is not known: {0}
|
||||||
|
XHTML_XHTML_ATTRIBUTE_XML_SPACE = The attribute 'xml:space' is legal in XHTML 1.0, and therefore in resources, but was removed in XHTML 1.1, and for this reason it''s use is strongly discouraged
|
||||||
|
|
|
@ -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>6.3.19-SNAPSHOT</version>
|
<version>6.3.20-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>6.3.19-SNAPSHOT</version>
|
<version>6.3.20-SNAPSHOT</version>
|
||||||
<relativePath>../pom.xml</relativePath>
|
<relativePath>../pom.xml</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
|
|
@ -3287,7 +3287,11 @@ public class InstanceValidator extends BaseValidator implements IResourceValidat
|
||||||
for (String an : node.getAttributes().keySet()) {
|
for (String an : node.getAttributes().keySet()) {
|
||||||
boolean bok = an.startsWith("xmlns") || HTML_ATTRIBUTES.contains(an) || HTML_COMBO_LIST.contains(node.getName() + "." + an);
|
boolean bok = an.startsWith("xmlns") || HTML_ATTRIBUTES.contains(an) || HTML_COMBO_LIST.contains(node.getName() + "." + an);
|
||||||
if (!bok) {
|
if (!bok) {
|
||||||
ok = rule(errors, NO_RULE_DATE, IssueType.INVALID, e.line(), e.col(), path, false, I18nConstants.XHTML_XHTML_ATTRIBUTE_ILLEGAL, an, node.getName()) && ok;
|
if ("xml:space".equals(an)) {
|
||||||
|
warning(errors, "2024-08-03", IssueType.INVALID, e.line(), e.col(), path, false, I18nConstants.XHTML_XHTML_ATTRIBUTE_XML_SPACE, an, node.getName());
|
||||||
|
} else {
|
||||||
|
ok = rule(errors, NO_RULE_DATE, IssueType.INVALID, e.line(), e.col(), path, false, I18nConstants.XHTML_XHTML_ATTRIBUTE_ILLEGAL, an, node.getName()) && ok;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3314,7 +3318,7 @@ public class InstanceValidator extends BaseValidator implements IResourceValidat
|
||||||
} else if (count > 1) {
|
} else if (count > 1) {
|
||||||
warning(errors, NO_RULE_DATE, IssueType.INVALID, e.line(), e.col(), path, false, I18nConstants.TYPE_SPECIFIC_CHECKS_DT_XHTML_MULTIPLE_MATCHES, href, xpath, node.allText(), CommaSeparatedStringBuilder.join(", ", refs));
|
warning(errors, NO_RULE_DATE, IssueType.INVALID, e.line(), e.col(), path, false, I18nConstants.TYPE_SPECIFIC_CHECKS_DT_XHTML_MULTIPLE_MATCHES, href, xpath, node.allText(), CommaSeparatedStringBuilder.join(", ", refs));
|
||||||
}
|
}
|
||||||
} else if (href.contains(":")) {
|
} else if (href.contains(":") && Utilities.isAbsoluteUrl(href)) {
|
||||||
String scheme = href.substring(0, href.indexOf(":"));
|
String scheme = href.substring(0, href.indexOf(":"));
|
||||||
if (rule(errors, "2024-07-20", IssueType.INVALID, e.line(), e.col(), path, !isActiveScheme(scheme), I18nConstants.TYPE_SPECIFIC_CHECKS_DT_XHTML_ACTIVE_HREF, href, xpath, Utilities.stripEoln(node.allText()).trim(), scheme)) {
|
if (rule(errors, "2024-07-20", IssueType.INVALID, e.line(), e.col(), path, !isActiveScheme(scheme), I18nConstants.TYPE_SPECIFIC_CHECKS_DT_XHTML_ACTIVE_HREF, href, xpath, Utilities.stripEoln(node.allText()).trim(), scheme)) {
|
||||||
if (rule(errors, "2024-07-20", IssueType.INVALID, e.line(), e.col(), path, isLiteralScheme(scheme), I18nConstants.TYPE_SPECIFIC_CHECKS_DT_XHTML_LITERAL_HREF, href, xpath, Utilities.stripEoln(node.allText()).trim(), scheme)) {
|
if (rule(errors, "2024-07-20", IssueType.INVALID, e.line(), e.col(), path, isLiteralScheme(scheme), I18nConstants.TYPE_SPECIFIC_CHECKS_DT_XHTML_LITERAL_HREF, href, xpath, Utilities.stripEoln(node.allText()).trim(), scheme)) {
|
||||||
|
|
|
@ -171,6 +171,8 @@ public class ConceptMapValidator extends BaseValidator {
|
||||||
for (CMCodingValidationRequest cv : batch) {
|
for (CMCodingValidationRequest cv : batch) {
|
||||||
if (cv.getResult().getErrorClass() == TerminologyServiceErrorClass.CODESYSTEM_UNSUPPORTED) {
|
if (cv.getResult().getErrorClass() == TerminologyServiceErrorClass.CODESYSTEM_UNSUPPORTED) {
|
||||||
warning(errors, "2023-09-06", IssueType.BUSINESSRULE, cv.getStack(), cv.getResult().isOk(), I18nConstants.CONCEPTMAP_VS_CONCEPT_CODE_UNKNOWN_SYSTEM, cv.getCoding().getSystem(), cv.getCoding().getCode(), cv.getVsObj().getUrl());
|
warning(errors, "2023-09-06", IssueType.BUSINESSRULE, cv.getStack(), cv.getResult().isOk(), I18nConstants.CONCEPTMAP_VS_CONCEPT_CODE_UNKNOWN_SYSTEM, cv.getCoding().getSystem(), cv.getCoding().getCode(), cv.getVsObj().getUrl());
|
||||||
|
} else if (cv.getResult().getErrorClass() == TerminologyServiceErrorClass.CODESYSTEM_UNSUPPORTED_VERSION) {
|
||||||
|
warning(errors, "2023-09-06", IssueType.BUSINESSRULE, cv.getStack(), cv.getResult().isOk(), I18nConstants.CONCEPTMAP_VS_CONCEPT_CODE_UNKNOWN_SYSTEM_VERSION, cv.getCoding().getSystem(), cv.getCoding().getCode(), cv.getVsObj().getUrl(), cv.getResult().getVersion());
|
||||||
} else if (cv.getCoding().getVersion() == null) {
|
} else if (cv.getCoding().getVersion() == null) {
|
||||||
ok = rule(errors, "2023-09-06", IssueType.BUSINESSRULE, cv.getStack(), cv.getResult().isOk(), I18nConstants.CONCEPTMAP_VS_INVALID_CONCEPT_CODE, cv.getCoding().getSystem(), cv.getCoding().getCode(), cv.getVsObj().getUrl()) && ok;
|
ok = rule(errors, "2023-09-06", IssueType.BUSINESSRULE, cv.getStack(), cv.getResult().isOk(), I18nConstants.CONCEPTMAP_VS_INVALID_CONCEPT_CODE, cv.getCoding().getSystem(), cv.getCoding().getCode(), cv.getVsObj().getUrl()) && ok;
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -736,13 +736,18 @@ public class StructureMapValidator extends BaseValidator {
|
||||||
type = "string";
|
type = "string";
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
rule(errors, "2023-03-01", IssueType.INVALID, target.line(), target.col(), stack.getLiteralPath(), false, I18nConstants.SM_TARGET_TRANSFORM_NOT_CHECKED, transform);
|
warning(errors, "2023-03-01", IssueType.INVALID, target.line(), target.col(), stack.getLiteralPath(), false, I18nConstants.SM_TARGET_TRANSFORM_NOT_CHECKED, transform);
|
||||||
ok = false;
|
// ok = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (vn != null && type != null) {
|
if (vn != null && type != null) {
|
||||||
StructureDefinition sdt = this.context.fetchTypeDefinition(type);
|
StructureDefinition sdt = this.context.fetchTypeDefinition(type);
|
||||||
vn.setType(ruleInfo.getMaxCount(), sdt, sdt.getSnapshot().getElementFirstRep(), null); // may overwrite
|
if (sdt != null) {
|
||||||
|
vn.setType(ruleInfo.getMaxCount(), sdt, sdt.getSnapshot().getElementFirstRep(), null); // may overwrite
|
||||||
|
} else {
|
||||||
|
ok = false;
|
||||||
|
rule(errors, "2023-07-30", IssueType.INVALID, target.line(), target.col(), stack.getLiteralPath(), false, I18nConstants.SM_TARGET_TYPE_UNKNOWN, type);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return ok;
|
return ok;
|
||||||
}
|
}
|
||||||
|
@ -905,8 +910,8 @@ public class StructureMapValidator extends BaseValidator {
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
rule(errors, "2023-03-01", IssueType.INVALID, target.line(), target.col(), stack.getLiteralPath(), false, I18nConstants.SM_TARGET_TRANSFORM_NOT_CHECKED, transform);
|
warning(errors, "2023-03-01", IssueType.INVALID, target.line(), target.col(), stack.getLiteralPath(), false, I18nConstants.SM_TARGET_TRANSFORM_NOT_CHECKED, transform);
|
||||||
ok = false;
|
// ok = false;
|
||||||
}
|
}
|
||||||
if (vn != null) {
|
if (vn != null) {
|
||||||
// it's just a warning: maybe this'll work out at run time?
|
// it's just a warning: maybe this'll work out at run time?
|
||||||
|
|
|
@ -7545,6 +7545,52 @@ v: {
|
||||||
"system" : "http://loinc.org",
|
"system" : "http://loinc.org",
|
||||||
"version" : "2.77",
|
"version" : "2.77",
|
||||||
"server" : "http://tx-dev.fhir.org/r4",
|
"server" : "http://tx-dev.fhir.org/r4",
|
||||||
|
"issues" : {
|
||||||
|
"resourceType" : "OperationOutcome"
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
-------------------------------------------------------------------------------------
|
||||||
|
{"code" : {
|
||||||
|
"system" : "http://loinc.org",
|
||||||
|
"code" : "58410-2",
|
||||||
|
"display" : "CBC panel - Blood by Automated count"
|
||||||
|
}, "valueSet" :null, "langs":"", "useServer":"true", "useClient":"false", "guessSystem":"false", "activeOnly":"false", "membershipOnly":"false", "displayWarningMode":"false", "versionFlexible":"false", "profile": {
|
||||||
|
"resourceType" : "Parameters",
|
||||||
|
"parameter" : [{
|
||||||
|
"name" : "profile-url",
|
||||||
|
"valueString" : "http://hl7.org/fhir/ExpansionProfile/dc8fd4bc-091a-424a-8a3b-6198ef146891"
|
||||||
|
}]
|
||||||
|
}}####
|
||||||
|
v: {
|
||||||
|
"display" : "CBC panel - Blood by Automated count",
|
||||||
|
"code" : "58410-2",
|
||||||
|
"system" : "http://loinc.org",
|
||||||
|
"version" : "2.77",
|
||||||
|
"server" : "http://tx-dev.fhir.org/r4",
|
||||||
|
"unknown-systems" : "",
|
||||||
|
"issues" : {
|
||||||
|
"resourceType" : "OperationOutcome"
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
-------------------------------------------------------------------------------------
|
||||||
|
{"code" : {
|
||||||
|
"system" : "http://loinc.org",
|
||||||
|
"code" : "58410-2"
|
||||||
|
}, "url": "http://hl7.org/fhir/ValueSet/report-codes--0", "version": "4.0.1", "langs":"", "useServer":"true", "useClient":"false", "guessSystem":"false", "activeOnly":"false", "membershipOnly":"false", "displayWarningMode":"false", "versionFlexible":"false", "profile": {
|
||||||
|
"resourceType" : "Parameters",
|
||||||
|
"parameter" : [{
|
||||||
|
"name" : "profile-url",
|
||||||
|
"valueString" : "http://hl7.org/fhir/ExpansionProfile/dc8fd4bc-091a-424a-8a3b-6198ef146891"
|
||||||
|
}]
|
||||||
|
}}####
|
||||||
|
v: {
|
||||||
|
"display" : "CBC panel - Blood by Automated count",
|
||||||
|
"code" : "58410-2",
|
||||||
|
"system" : "http://loinc.org",
|
||||||
|
"version" : "2.77",
|
||||||
|
"server" : "http://tx-dev.fhir.org/r4",
|
||||||
"unknown-systems" : "",
|
"unknown-systems" : "",
|
||||||
"issues" : {
|
"issues" : {
|
||||||
"resourceType" : "OperationOutcome"
|
"resourceType" : "OperationOutcome"
|
||||||
|
|
4
pom.xml
4
pom.xml
|
@ -14,14 +14,14 @@
|
||||||
HAPI FHIR
|
HAPI FHIR
|
||||||
-->
|
-->
|
||||||
<artifactId>org.hl7.fhir.core</artifactId>
|
<artifactId>org.hl7.fhir.core</artifactId>
|
||||||
<version>6.3.19-SNAPSHOT</version>
|
<version>6.3.20-SNAPSHOT</version>
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
|
||||||
<properties>
|
<properties>
|
||||||
<commons_compress_version>1.26.0</commons_compress_version>
|
<commons_compress_version>1.26.0</commons_compress_version>
|
||||||
<guava_version>32.0.1-jre</guava_version>
|
<guava_version>32.0.1-jre</guava_version>
|
||||||
<hapi_fhir_version>6.4.1</hapi_fhir_version>
|
<hapi_fhir_version>6.4.1</hapi_fhir_version>
|
||||||
<validator_test_case_version>1.5.17-SNAPSHOT</validator_test_case_version>
|
<validator_test_case_version>1.5.17</validator_test_case_version>
|
||||||
<jackson_version>2.17.0</jackson_version>
|
<jackson_version>2.17.0</jackson_version>
|
||||||
<junit_jupiter_version>5.9.2</junit_jupiter_version>
|
<junit_jupiter_version>5.9.2</junit_jupiter_version>
|
||||||
<junit_platform_launcher_version>1.8.2</junit_platform_launcher_version>
|
<junit_platform_launcher_version>1.8.2</junit_platform_launcher_version>
|
||||||
|
|
Loading…
Reference in New Issue