Remove some cruft from the model
This commit is contained in:
parent
25f8d8d22d
commit
8a933cd2c2
|
@ -28,13 +28,11 @@ import java.util.Set;
|
||||||
|
|
||||||
import org.hl7.fhir.instance.model.api.IBase;
|
import org.hl7.fhir.instance.model.api.IBase;
|
||||||
|
|
||||||
import ca.uhn.fhir.model.api.ICodeEnum;
|
|
||||||
import ca.uhn.fhir.model.api.annotation.Child;
|
import ca.uhn.fhir.model.api.annotation.Child;
|
||||||
import ca.uhn.fhir.model.api.annotation.Description;
|
import ca.uhn.fhir.model.api.annotation.Description;
|
||||||
|
|
||||||
public abstract class BaseRuntimeChildDatatypeDefinition extends BaseRuntimeDeclaredChildDefinition {
|
public abstract class BaseRuntimeChildDatatypeDefinition extends BaseRuntimeDeclaredChildDefinition {
|
||||||
|
|
||||||
private Class<? extends ICodeEnum> myCodeType;
|
|
||||||
private Class<? extends IBase> myDatatype;
|
private Class<? extends IBase> myDatatype;
|
||||||
|
|
||||||
private BaseRuntimeElementDefinition<?> myElementDefinition;
|
private BaseRuntimeElementDefinition<?> myElementDefinition;
|
||||||
|
@ -87,10 +85,6 @@ public abstract class BaseRuntimeChildDatatypeDefinition extends BaseRuntimeDecl
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Class<? extends ICodeEnum> getCodeType() {
|
|
||||||
return myCodeType;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Class<? extends IBase> getDatatype() {
|
public Class<? extends IBase> getDatatype() {
|
||||||
return myDatatype;
|
return myDatatype;
|
||||||
}
|
}
|
||||||
|
@ -106,13 +100,6 @@ public abstract class BaseRuntimeChildDatatypeDefinition extends BaseRuntimeDecl
|
||||||
assert myElementDefinition != null : "Unknown type: " + getDatatype();
|
assert myElementDefinition != null : "Unknown type: " + getDatatype();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setCodeType(Class<? extends ICodeEnum> theType) {
|
|
||||||
if (myElementDefinition != null) {
|
|
||||||
throw new IllegalStateException("Can not set code type at runtime");
|
|
||||||
}
|
|
||||||
myCodeType = theType;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return getClass().getSimpleName() + "[" + getElementName() + "]";
|
return getClass().getSimpleName() + "[" + getElementName() + "]";
|
||||||
|
|
|
@ -39,7 +39,6 @@ import java.util.LinkedList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Map.Entry;
|
import java.util.Map.Entry;
|
||||||
import java.util.concurrent.ThreadFactory;
|
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.TreeMap;
|
import java.util.TreeMap;
|
||||||
|
@ -60,10 +59,8 @@ import org.hl7.fhir.instance.model.api.IIdType;
|
||||||
import org.hl7.fhir.instance.model.api.INarrative;
|
import org.hl7.fhir.instance.model.api.INarrative;
|
||||||
import org.hl7.fhir.instance.model.api.IPrimitiveType;
|
import org.hl7.fhir.instance.model.api.IPrimitiveType;
|
||||||
|
|
||||||
import ca.uhn.fhir.model.api.CodeableConceptElement;
|
|
||||||
import ca.uhn.fhir.model.api.ExtensionDt;
|
import ca.uhn.fhir.model.api.ExtensionDt;
|
||||||
import ca.uhn.fhir.model.api.IBoundCodeableConcept;
|
import ca.uhn.fhir.model.api.IBoundCodeableConcept;
|
||||||
import ca.uhn.fhir.model.api.ICodeEnum;
|
|
||||||
import ca.uhn.fhir.model.api.IDatatype;
|
import ca.uhn.fhir.model.api.IDatatype;
|
||||||
import ca.uhn.fhir.model.api.IElement;
|
import ca.uhn.fhir.model.api.IElement;
|
||||||
import ca.uhn.fhir.model.api.IResource;
|
import ca.uhn.fhir.model.api.IResource;
|
||||||
|
@ -82,7 +79,6 @@ import ca.uhn.fhir.model.base.composite.BaseContainedDt;
|
||||||
import ca.uhn.fhir.model.base.composite.BaseNarrativeDt;
|
import ca.uhn.fhir.model.base.composite.BaseNarrativeDt;
|
||||||
import ca.uhn.fhir.model.base.composite.BaseResourceReferenceDt;
|
import ca.uhn.fhir.model.base.composite.BaseResourceReferenceDt;
|
||||||
import ca.uhn.fhir.model.primitive.BoundCodeDt;
|
import ca.uhn.fhir.model.primitive.BoundCodeDt;
|
||||||
import ca.uhn.fhir.model.primitive.ICodedDatatype;
|
|
||||||
import ca.uhn.fhir.model.primitive.XhtmlDt;
|
import ca.uhn.fhir.model.primitive.XhtmlDt;
|
||||||
import ca.uhn.fhir.rest.method.RestSearchParameterTypeEnum;
|
import ca.uhn.fhir.rest.method.RestSearchParameterTypeEnum;
|
||||||
import ca.uhn.fhir.util.ReflectionUtil;
|
import ca.uhn.fhir.util.ReflectionUtil;
|
||||||
|
@ -98,7 +94,6 @@ class ModelScanner {
|
||||||
private Map<String, Class<? extends IBaseResource>> myNameToResourceType = new HashMap<String, Class<? extends IBaseResource>>();
|
private Map<String, Class<? extends IBaseResource>> myNameToResourceType = new HashMap<String, Class<? extends IBaseResource>>();
|
||||||
private RuntimeChildUndeclaredExtensionDefinition myRuntimeChildUndeclaredExtensionDefinition;
|
private RuntimeChildUndeclaredExtensionDefinition myRuntimeChildUndeclaredExtensionDefinition;
|
||||||
private Set<Class<? extends IBase>> myScanAlso = new HashSet<Class<? extends IBase>>();
|
private Set<Class<? extends IBase>> myScanAlso = new HashSet<Class<? extends IBase>>();
|
||||||
private Set<Class<? extends ICodeEnum>> myScanAlsoCodeTable = new HashSet<Class<? extends ICodeEnum>>();
|
|
||||||
private FhirVersionEnum myVersion;
|
private FhirVersionEnum myVersion;
|
||||||
|
|
||||||
private Set<Class<? extends IBase>> myVersionTypes;
|
private Set<Class<? extends IBase>> myVersionTypes;
|
||||||
|
@ -651,18 +646,6 @@ class ModelScanner {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
CodeableConceptElement concept = pullAnnotation(next, CodeableConceptElement.class);
|
|
||||||
if (concept != null) {
|
|
||||||
if (!ICodedDatatype.class.isAssignableFrom(nextDatatype)) {
|
|
||||||
throw new ConfigurationException("Field '" + elementName + "' in type '" + theClass.getCanonicalName() + "' is marked as @" + CodeableConceptElement.class.getCanonicalName()
|
|
||||||
+ " but type is not a subtype of " + ICodedDatatype.class.getName());
|
|
||||||
} else {
|
|
||||||
Class<? extends ICodeEnum> type = concept.type();
|
|
||||||
myScanAlsoCodeTable.add(type);
|
|
||||||
def.setCodeType(type);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
orderMap.put(order, def);
|
orderMap.put(order, def);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -1,449 +0,0 @@
|
||||||
package ca.uhn.fhir.model.api;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* #%L
|
|
||||||
* HAPI FHIR - Core Library
|
|
||||||
* %%
|
|
||||||
* Copyright (C) 2014 - 2015 University Health Network
|
|
||||||
* %%
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
* #L%
|
|
||||||
*/
|
|
||||||
|
|
||||||
import static org.apache.commons.lang3.StringUtils.*;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
import org.apache.commons.lang3.StringUtils;
|
|
||||||
import org.apache.commons.lang3.Validate;
|
|
||||||
import org.apache.commons.lang3.builder.ToStringBuilder;
|
|
||||||
import org.apache.commons.lang3.builder.ToStringStyle;
|
|
||||||
import org.hl7.fhir.instance.model.api.IBase;
|
|
||||||
|
|
||||||
import ca.uhn.fhir.context.FhirContext;
|
|
||||||
import ca.uhn.fhir.context.RuntimeResourceDefinition;
|
|
||||||
import ca.uhn.fhir.model.base.resource.ResourceMetadataMap;
|
|
||||||
import ca.uhn.fhir.model.primitive.BoundCodeDt;
|
|
||||||
import ca.uhn.fhir.model.primitive.DecimalDt;
|
|
||||||
import ca.uhn.fhir.model.primitive.IdDt;
|
|
||||||
import ca.uhn.fhir.model.primitive.InstantDt;
|
|
||||||
import ca.uhn.fhir.model.primitive.IntegerDt;
|
|
||||||
import ca.uhn.fhir.model.primitive.StringDt;
|
|
||||||
import ca.uhn.fhir.model.valueset.BundleEntrySearchModeEnum;
|
|
||||||
import ca.uhn.fhir.model.valueset.BundleEntryTransactionMethodEnum;
|
|
||||||
import ca.uhn.fhir.model.valueset.BundleTypeEnum;
|
|
||||||
import ca.uhn.fhir.rest.server.Constants;
|
|
||||||
import ca.uhn.fhir.util.UrlUtil;
|
|
||||||
|
|
||||||
public class Bundle extends BaseBundle implements IBase /* implements IElement */{
|
|
||||||
|
|
||||||
private ResourceMetadataMap myResourceMetadata;
|
|
||||||
private BoundCodeDt<BundleTypeEnum> myType;
|
|
||||||
private StringDt myBundleId;
|
|
||||||
private TagList myCategories;
|
|
||||||
private List<BundleEntry> myEntries;
|
|
||||||
private volatile transient Map<IdDt, IResource> myIdToEntries;
|
|
||||||
private StringDt myLinkBase;
|
|
||||||
private StringDt myLinkFirst;
|
|
||||||
private StringDt myLinkLast;
|
|
||||||
private StringDt myLinkNext;
|
|
||||||
private StringDt myLinkPrevious;
|
|
||||||
private StringDt myLinkSelf;
|
|
||||||
private StringDt myTitle;
|
|
||||||
private IntegerDt myTotalResults;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @deprecated Tags wil become immutable in a future release of HAPI, so
|
|
||||||
* {@link #addCategory(String, String, String)} should be used instead
|
|
||||||
*/
|
|
||||||
@Deprecated
|
|
||||||
public Tag addCategory() {
|
|
||||||
Tag retVal = new Tag();
|
|
||||||
getCategories().add(retVal);
|
|
||||||
return retVal;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void addCategory(String theScheme, String theTerm, String theLabel) {
|
|
||||||
getCategories().add(new Tag(theScheme, theTerm, theLabel));
|
|
||||||
}
|
|
||||||
|
|
||||||
public void addCategory(Tag theTag) {
|
|
||||||
getCategories().add(theTag);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Adds and returns a new bundle entry
|
|
||||||
*/
|
|
||||||
public BundleEntry addEntry() {
|
|
||||||
BundleEntry retVal = new BundleEntry();
|
|
||||||
getEntries().add(retVal);
|
|
||||||
return retVal;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Adds a new entry
|
|
||||||
*
|
|
||||||
* @param theBundleEntry
|
|
||||||
* The entry to add
|
|
||||||
*/
|
|
||||||
public void addEntry(BundleEntry theBundleEntry) {
|
|
||||||
Validate.notNull(theBundleEntry, "theBundleEntry can not be null");
|
|
||||||
getEntries().add(theBundleEntry);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates a new entry using the given resource and populates it accordingly
|
|
||||||
*
|
|
||||||
* @param theResource
|
|
||||||
* The resource to add
|
|
||||||
* @return Returns the newly created bundle entry that was added to the bundle
|
|
||||||
*/
|
|
||||||
public BundleEntry addResource(IResource theResource, FhirContext theContext, String theServerBase) {
|
|
||||||
BundleEntry entry = addEntry();
|
|
||||||
entry.setResource(theResource);
|
|
||||||
|
|
||||||
RuntimeResourceDefinition def = theContext.getResourceDefinition(theResource);
|
|
||||||
|
|
||||||
String title = ResourceMetadataKeyEnum.TITLE.get(theResource);
|
|
||||||
if (title != null) {
|
|
||||||
entry.getTitle().setValue(title);
|
|
||||||
} else {
|
|
||||||
entry.getTitle().setValue(def.getName() + " " + StringUtils.defaultString(theResource.getId().getValue(), "(no ID)"));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (theResource.getId() != null) {
|
|
||||||
if (theResource.getId().isAbsolute()) {
|
|
||||||
|
|
||||||
entry.getLinkSelf().setValue(theResource.getId().getValue());
|
|
||||||
entry.getId().setValue(theResource.getId().toVersionless().getValue());
|
|
||||||
|
|
||||||
} else if (StringUtils.isNotBlank(theResource.getId().getValue())) {
|
|
||||||
|
|
||||||
StringBuilder b = new StringBuilder();
|
|
||||||
b.append(theServerBase);
|
|
||||||
if (b.length() > 0 && b.charAt(b.length() - 1) != '/') {
|
|
||||||
b.append('/');
|
|
||||||
}
|
|
||||||
b.append(def.getName());
|
|
||||||
b.append('/');
|
|
||||||
String resId = theResource.getId().getIdPart();
|
|
||||||
b.append(resId);
|
|
||||||
|
|
||||||
entry.getId().setValue(b.toString());
|
|
||||||
|
|
||||||
if (isNotBlank(theResource.getId().getVersionIdPart())) {
|
|
||||||
b.append('/');
|
|
||||||
b.append(Constants.PARAM_HISTORY);
|
|
||||||
b.append('/');
|
|
||||||
b.append(theResource.getId().getVersionIdPart());
|
|
||||||
} else {
|
|
||||||
IdDt versionId = (IdDt) ResourceMetadataKeyEnum.VERSION_ID.get(theResource);
|
|
||||||
if (versionId != null) {
|
|
||||||
b.append('/');
|
|
||||||
b.append(Constants.PARAM_HISTORY);
|
|
||||||
b.append('/');
|
|
||||||
b.append(versionId.getValue());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
String qualifiedId = b.toString();
|
|
||||||
entry.getLinkSelf().setValue(qualifiedId);
|
|
||||||
|
|
||||||
// String resourceType = theContext.getResourceDefinition(theResource).getName();
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
InstantDt published = ResourceMetadataKeyEnum.PUBLISHED.get(theResource);
|
|
||||||
if (published == null) {
|
|
||||||
entry.getPublished().setToCurrentTimeInLocalTimeZone();
|
|
||||||
} else {
|
|
||||||
entry.setPublished(published);
|
|
||||||
}
|
|
||||||
|
|
||||||
InstantDt updated = ResourceMetadataKeyEnum.UPDATED.get(theResource);
|
|
||||||
if (updated != null) {
|
|
||||||
entry.setUpdated(updated);
|
|
||||||
}
|
|
||||||
|
|
||||||
InstantDt deleted = ResourceMetadataKeyEnum.DELETED_AT.get(theResource);
|
|
||||||
if (deleted != null) {
|
|
||||||
entry.setDeleted(deleted);
|
|
||||||
}
|
|
||||||
|
|
||||||
IdDt previous = ResourceMetadataKeyEnum.PREVIOUS_ID.get(theResource);
|
|
||||||
if (previous != null) {
|
|
||||||
entry.getLinkAlternate().setValue(previous.withServerBase(theServerBase, def.getName()).getValue());
|
|
||||||
}
|
|
||||||
|
|
||||||
TagList tagList = ResourceMetadataKeyEnum.TAG_LIST.get(theResource);
|
|
||||||
if (tagList != null) {
|
|
||||||
for (Tag nextTag : tagList) {
|
|
||||||
entry.addCategory(nextTag);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
String linkSearch = ResourceMetadataKeyEnum.LINK_SEARCH.get(theResource);
|
|
||||||
if (isNotBlank(linkSearch)) {
|
|
||||||
if (!UrlUtil.isAbsolute(linkSearch)) {
|
|
||||||
linkSearch = (theServerBase + "/" + linkSearch);
|
|
||||||
}
|
|
||||||
entry.getLinkSearch().setValue(linkSearch);
|
|
||||||
}
|
|
||||||
|
|
||||||
String linkAlternate = ResourceMetadataKeyEnum.LINK_ALTERNATE.get(theResource);
|
|
||||||
if (isNotBlank(linkAlternate)) {
|
|
||||||
if (!UrlUtil.isAbsolute(linkAlternate)) {
|
|
||||||
linkSearch = (theServerBase + "/" + linkAlternate);
|
|
||||||
}
|
|
||||||
entry.getLinkAlternate().setValue(linkSearch);
|
|
||||||
}
|
|
||||||
|
|
||||||
BundleEntrySearchModeEnum entryStatus = ResourceMetadataKeyEnum.ENTRY_SEARCH_MODE.get(theResource);
|
|
||||||
if (entryStatus != null) {
|
|
||||||
entry.getSearchMode().setValueAsEnum(entryStatus);
|
|
||||||
}
|
|
||||||
|
|
||||||
BundleEntryTransactionMethodEnum entryTransactionOperation = ResourceMetadataKeyEnum.ENTRY_TRANSACTION_METHOD.get(theResource);
|
|
||||||
if (entryTransactionOperation != null) {
|
|
||||||
entry.getTransactionMethod().setValueAsEnum(entryTransactionOperation);
|
|
||||||
}
|
|
||||||
|
|
||||||
DecimalDt entryScore = ResourceMetadataKeyEnum.ENTRY_SCORE.get(theResource);
|
|
||||||
if (entryScore != null) {
|
|
||||||
entry.setScore(entryScore);
|
|
||||||
}
|
|
||||||
|
|
||||||
return entry;
|
|
||||||
}
|
|
||||||
|
|
||||||
public StringDt getBundleId() {
|
|
||||||
if (myBundleId == null) {
|
|
||||||
myBundleId = new StringDt();
|
|
||||||
}
|
|
||||||
return myBundleId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public TagList getCategories() {
|
|
||||||
if (myCategories == null) {
|
|
||||||
myCategories = new TagList();
|
|
||||||
}
|
|
||||||
return myCategories;
|
|
||||||
}
|
|
||||||
|
|
||||||
public List<BundleEntry> getEntries() {
|
|
||||||
if (myEntries == null) {
|
|
||||||
myEntries = new ArrayList<BundleEntry>();
|
|
||||||
}
|
|
||||||
return myEntries;
|
|
||||||
}
|
|
||||||
|
|
||||||
public StringDt getLinkBase() {
|
|
||||||
if (myLinkBase == null) {
|
|
||||||
myLinkBase = new StringDt();
|
|
||||||
}
|
|
||||||
return myLinkBase;
|
|
||||||
}
|
|
||||||
|
|
||||||
public StringDt getLinkFirst() {
|
|
||||||
if (myLinkFirst == null) {
|
|
||||||
myLinkFirst = new StringDt();
|
|
||||||
}
|
|
||||||
return myLinkFirst;
|
|
||||||
}
|
|
||||||
|
|
||||||
public StringDt getLinkLast() {
|
|
||||||
if (myLinkLast == null) {
|
|
||||||
myLinkLast = new StringDt();
|
|
||||||
}
|
|
||||||
return myLinkLast;
|
|
||||||
}
|
|
||||||
|
|
||||||
public StringDt getLinkNext() {
|
|
||||||
if (myLinkNext == null) {
|
|
||||||
myLinkNext = new StringDt();
|
|
||||||
}
|
|
||||||
return myLinkNext;
|
|
||||||
}
|
|
||||||
|
|
||||||
public StringDt getLinkPrevious() {
|
|
||||||
if (myLinkPrevious == null) {
|
|
||||||
myLinkPrevious = new StringDt();
|
|
||||||
}
|
|
||||||
return myLinkPrevious;
|
|
||||||
}
|
|
||||||
|
|
||||||
public StringDt getLinkSelf() {
|
|
||||||
if (myLinkSelf == null) {
|
|
||||||
myLinkSelf = new StringDt();
|
|
||||||
}
|
|
||||||
return myLinkSelf;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
public InstantDt getPublished() {
|
|
||||||
InstantDt retVal = (InstantDt) getResourceMetadata().get(ResourceMetadataKeyEnum.PUBLISHED);
|
|
||||||
if (retVal == null) {
|
|
||||||
retVal= new InstantDt();
|
|
||||||
getResourceMetadata().put(ResourceMetadataKeyEnum.PUBLISHED, retVal);
|
|
||||||
}
|
|
||||||
return retVal;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Retrieves a resource from a bundle given its logical ID.
|
|
||||||
* <p>
|
|
||||||
* <b>Important usage notes</b>: This method ignores base URLs (so passing in an ID of
|
|
||||||
* <code>http://foo/Patient/123</code> will return a resource if it has the logical ID of
|
|
||||||
* <code>http://bar/Patient/123</code>. Also, this method is intended to be used for bundles which have already been
|
|
||||||
* populated. It will cache its results for fast performance, but that means that modifications to the bundle after
|
|
||||||
* this method is called may not be accurately reflected.
|
|
||||||
* </p>
|
|
||||||
*
|
|
||||||
* @param theId
|
|
||||||
* The resource ID
|
|
||||||
* @return Returns the resource with the given ID, or <code>null</code> if none is found
|
|
||||||
*/
|
|
||||||
public IResource getResourceById(IdDt theId) {
|
|
||||||
Map<IdDt, IResource> map = myIdToEntries;
|
|
||||||
if (map == null) {
|
|
||||||
map = new HashMap<IdDt, IResource>();
|
|
||||||
for (BundleEntry next : this.getEntries()) {
|
|
||||||
if (next.getId().isEmpty() == false) {
|
|
||||||
map.put(next.getId().toUnqualified(), next.getResource());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
myIdToEntries = map;
|
|
||||||
}
|
|
||||||
return map.get(theId.toUnqualified());
|
|
||||||
}
|
|
||||||
|
|
||||||
public ResourceMetadataMap getResourceMetadata() {
|
|
||||||
if (myResourceMetadata == null) {
|
|
||||||
myResourceMetadata = new ResourceMetadataMap();
|
|
||||||
}
|
|
||||||
return myResourceMetadata;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns a list containing all resources of the given type from this bundle
|
|
||||||
*/
|
|
||||||
public <T extends IResource> List<T> getResources(Class<T> theClass) {
|
|
||||||
ArrayList<T> retVal = new ArrayList<T>();
|
|
||||||
for (BundleEntry next : getEntries()) {
|
|
||||||
if (next.getResource() != null && theClass.isAssignableFrom(next.getResource().getClass())) {
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
T resource = (T) next.getResource();
|
|
||||||
retVal.add(resource);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return retVal;
|
|
||||||
}
|
|
||||||
|
|
||||||
public StringDt getTitle() {
|
|
||||||
if (myTitle == null) {
|
|
||||||
myTitle = new StringDt();
|
|
||||||
}
|
|
||||||
return myTitle;
|
|
||||||
}
|
|
||||||
|
|
||||||
public IntegerDt getTotalResults() {
|
|
||||||
if (myTotalResults == null) {
|
|
||||||
myTotalResults = new IntegerDt();
|
|
||||||
}
|
|
||||||
return myTotalResults;
|
|
||||||
}
|
|
||||||
|
|
||||||
public BoundCodeDt<BundleTypeEnum> getType() {
|
|
||||||
if (myType == null) {
|
|
||||||
myType = new BoundCodeDt<BundleTypeEnum>(BundleTypeEnum.VALUESET_BINDER);
|
|
||||||
}
|
|
||||||
return myType;
|
|
||||||
}
|
|
||||||
|
|
||||||
public InstantDt getUpdated() {
|
|
||||||
InstantDt retVal = (InstantDt) getResourceMetadata().get(ResourceMetadataKeyEnum.UPDATED);
|
|
||||||
if (retVal == null) {
|
|
||||||
retVal= new InstantDt();
|
|
||||||
getResourceMetadata().put(ResourceMetadataKeyEnum.UPDATED, retVal);
|
|
||||||
}
|
|
||||||
return retVal;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns true if this bundle contains zero entries
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public boolean isEmpty() {
|
|
||||||
return getEntries().isEmpty();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setCategories(TagList theCategories) {
|
|
||||||
myCategories = theCategories;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
public void setPublished(InstantDt thePublished) {
|
|
||||||
getResourceMetadata().put(ResourceMetadataKeyEnum.PUBLISHED, thePublished);
|
|
||||||
}
|
|
||||||
/*
|
|
||||||
|
|
||||||
public void setType(BoundCodeDt<BundleTypeEnum> theType) {
|
|
||||||
myType = theType;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the number of entries in this bundle
|
|
||||||
*/
|
|
||||||
public int size() {
|
|
||||||
return getEntries().size();
|
|
||||||
}
|
|
||||||
|
|
||||||
public List<IResource> toListOfResources() {
|
|
||||||
ArrayList<IResource> retVal = new ArrayList<IResource>();
|
|
||||||
for (BundleEntry next : getEntries()) {
|
|
||||||
if (next.getResource() != null) {
|
|
||||||
retVal.add(next.getResource());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return retVal;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
ToStringBuilder b = new ToStringBuilder(this, ToStringStyle.SHORT_PREFIX_STYLE);
|
|
||||||
b.append(getEntries().size() + " entries");
|
|
||||||
b.append("id", getId());
|
|
||||||
return b.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
public static Bundle withResources(List<IResource> theResources, FhirContext theContext, String theServerBase) {
|
|
||||||
Bundle retVal = new Bundle();
|
|
||||||
for (IResource next : theResources) {
|
|
||||||
retVal.addResource(next, theContext, theServerBase);
|
|
||||||
}
|
|
||||||
return retVal;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static Bundle withSingleResource(IResource theResource) {
|
|
||||||
Bundle retVal = new Bundle();
|
|
||||||
retVal.addEntry().setResource(theResource);
|
|
||||||
return retVal;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,35 +0,0 @@
|
||||||
package ca.uhn.fhir.model.api;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* #%L
|
|
||||||
* HAPI FHIR - Core Library
|
|
||||||
* %%
|
|
||||||
* Copyright (C) 2014 - 2016 University Health Network
|
|
||||||
* %%
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
* #L%
|
|
||||||
*/
|
|
||||||
|
|
||||||
import java.lang.annotation.ElementType;
|
|
||||||
import java.lang.annotation.Retention;
|
|
||||||
import java.lang.annotation.RetentionPolicy;
|
|
||||||
import java.lang.annotation.Target;
|
|
||||||
|
|
||||||
|
|
||||||
@Retention(RetentionPolicy.RUNTIME)
|
|
||||||
@Target(value= {ElementType.FIELD})
|
|
||||||
public @interface CodeableConceptElement {
|
|
||||||
|
|
||||||
Class<? extends ICodeEnum> type();
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,25 +0,0 @@
|
||||||
package ca.uhn.fhir.model.api;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* #%L
|
|
||||||
* HAPI FHIR - Core Library
|
|
||||||
* %%
|
|
||||||
* Copyright (C) 2014 - 2016 University Health Network
|
|
||||||
* %%
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
* #L%
|
|
||||||
*/
|
|
||||||
|
|
||||||
public interface ICodeEnum {
|
|
||||||
// nothing yet
|
|
||||||
}
|
|
|
@ -27,7 +27,7 @@ import ca.uhn.fhir.model.api.annotation.DatatypeDef;
|
||||||
import ca.uhn.fhir.model.api.annotation.SimpleSetter;
|
import ca.uhn.fhir.model.api.annotation.SimpleSetter;
|
||||||
|
|
||||||
@DatatypeDef(name = "code", profileOf=StringDt.class)
|
@DatatypeDef(name = "code", profileOf=StringDt.class)
|
||||||
public class CodeDt extends BasePrimitive<String> implements ICodedDatatype, Comparable<CodeDt> {
|
public class CodeDt extends BasePrimitive<String> implements Comparable<CodeDt> {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructor
|
* Constructor
|
||||||
|
|
|
@ -1,27 +0,0 @@
|
||||||
package ca.uhn.fhir.model.primitive;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* #%L
|
|
||||||
* HAPI FHIR - Core Library
|
|
||||||
* %%
|
|
||||||
* Copyright (C) 2014 - 2016 University Health Network
|
|
||||||
* %%
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
* #L%
|
|
||||||
*/
|
|
||||||
|
|
||||||
import ca.uhn.fhir.model.api.IDatatype;
|
|
||||||
|
|
||||||
public interface ICodedDatatype extends IDatatype {
|
|
||||||
// nothing
|
|
||||||
}
|
|
|
@ -25,6 +25,7 @@ import org.hl7.fhir.instance.model.api.IBaseResource;
|
||||||
import org.hl7.fhir.instance.model.api.IIdType;
|
import org.hl7.fhir.instance.model.api.IIdType;
|
||||||
|
|
||||||
import ca.uhn.fhir.model.primitive.IdDt;
|
import ca.uhn.fhir.model.primitive.IdDt;
|
||||||
|
import ca.uhn.fhir.util.CoverageIgnore;
|
||||||
|
|
||||||
public class MethodOutcome {
|
public class MethodOutcome {
|
||||||
|
|
||||||
|
@ -51,6 +52,7 @@ public class MethodOutcome {
|
||||||
* If not null, indicates whether the resource was created (as opposed to being updated). This is generally not needed, since the server can assume based on the method being called
|
* If not null, indicates whether the resource was created (as opposed to being updated). This is generally not needed, since the server can assume based on the method being called
|
||||||
* whether the result was a creation or an update. However, it can be useful if you are implementing an update method that does a create if the ID doesn't already exist.
|
* whether the result was a creation or an update. However, it can be useful if you are implementing an update method that does a create if the ID doesn't already exist.
|
||||||
*/
|
*/
|
||||||
|
@CoverageIgnore
|
||||||
public MethodOutcome(IIdType theId, Boolean theCreated) {
|
public MethodOutcome(IIdType theId, Boolean theCreated) {
|
||||||
myId = theId;
|
myId = theId;
|
||||||
myCreated = theCreated;
|
myCreated = theCreated;
|
||||||
|
@ -93,6 +95,7 @@ public class MethodOutcome {
|
||||||
* @deprecated Use the constructor which accepts a single IIdType parameter, and include the logical ID and version ID in that IIdType instance
|
* @deprecated Use the constructor which accepts a single IIdType parameter, and include the logical ID and version ID in that IIdType instance
|
||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated
|
||||||
|
@CoverageIgnore
|
||||||
public MethodOutcome(IIdType theId, IdDt theVersionId) {
|
public MethodOutcome(IIdType theId, IdDt theVersionId) {
|
||||||
myId = theId;
|
myId = theId;
|
||||||
myVersionId = theVersionId;
|
myVersionId = theVersionId;
|
||||||
|
@ -102,6 +105,7 @@ public class MethodOutcome {
|
||||||
* @deprecated Use the constructor which accepts a single IdDt parameter, and include the logical ID and version ID in that IdDt instance
|
* @deprecated Use the constructor which accepts a single IdDt parameter, and include the logical ID and version ID in that IdDt instance
|
||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated
|
||||||
|
@CoverageIgnore
|
||||||
public MethodOutcome(IIdType theId, IdDt theVersionId, IBaseOperationOutcome theBaseOperationOutcome) {
|
public MethodOutcome(IIdType theId, IdDt theVersionId, IBaseOperationOutcome theBaseOperationOutcome) {
|
||||||
myId = theId;
|
myId = theId;
|
||||||
myVersionId = theVersionId;
|
myVersionId = theVersionId;
|
||||||
|
@ -152,6 +156,7 @@ public class MethodOutcome {
|
||||||
* @deprecated {@link MethodOutcome#getId()} should return the complete ID including version if it is available
|
* @deprecated {@link MethodOutcome#getId()} should return the complete ID including version if it is available
|
||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated
|
||||||
|
@CoverageIgnore
|
||||||
public IdDt getVersionId() {
|
public IdDt getVersionId() {
|
||||||
return myVersionId;
|
return myVersionId;
|
||||||
}
|
}
|
||||||
|
@ -204,6 +209,7 @@ public class MethodOutcome {
|
||||||
* @deprecated Put the ID and version ID into the same IdDt instance and pass it to {@link #setId(IIdType)}
|
* @deprecated Put the ID and version ID into the same IdDt instance and pass it to {@link #setId(IIdType)}
|
||||||
*/
|
*/
|
||||||
@Deprecated
|
@Deprecated
|
||||||
|
@CoverageIgnore
|
||||||
public void setVersionId(IdDt theVersionId) {
|
public void setVersionId(IdDt theVersionId) {
|
||||||
myVersionId = theVersionId;
|
myVersionId = theVersionId;
|
||||||
}
|
}
|
||||||
|
|
|
@ -52,13 +52,4 @@ public abstract class ParseAction<T> {
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
public static ParseAction<IBaseResource> create(IBaseResource outcome) {
|
|
||||||
return outcome == null ? null : new ParseAction<IBaseResource>(outcome) {
|
|
||||||
@Override
|
|
||||||
public void execute(IParser theParser, Writer theWriter) throws IOException {
|
|
||||||
theParser.encodeResourceToWriter(this.theOutcome, theWriter);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,29 +1,10 @@
|
||||||
package ca.uhn.fhir.util;
|
package ca.uhn.fhir.util;
|
||||||
|
|
||||||
/*
|
|
||||||
* #%L
|
|
||||||
* HAPI FHIR - Core Library
|
|
||||||
* %%
|
|
||||||
* Copyright (C) 2014 - 2016 University Health Network
|
|
||||||
* %%
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
* #L%
|
|
||||||
*/
|
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Used internally by HAPI to log the version of the HAPI FHIR framework
|
* Used internally by HAPI to log the version of the HAPI FHIR framework
|
||||||
* once, when the framework is first loaded by the classloader.
|
* once, when the framework is first loaded by the classloader.
|
||||||
|
@ -49,20 +30,11 @@ public class VersionUtil {
|
||||||
p.load(is);
|
p.load(is);
|
||||||
ourVersion = p.getProperty("version");
|
ourVersion = p.getProperty("version");
|
||||||
ourLog.info("HAPI FHIR version is: " + ourVersion);
|
ourLog.info("HAPI FHIR version is: " + ourVersion);
|
||||||
} catch (IOException e) {
|
} catch (Exception e) {
|
||||||
ourLog.warn("Unable to determine HAPI version information", e);
|
ourLog.warn("Unable to determine HAPI version information", e);
|
||||||
} finally {
|
} finally {
|
||||||
if (is != null) {
|
IOUtils.closeQuietly(is);
|
||||||
try {
|
|
||||||
is.close();
|
|
||||||
} catch (IOException e) {
|
|
||||||
// ignore
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void main(String[] args) {
|
|
||||||
getVersion();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue