diff --git a/examples/pom.xml b/examples/pom.xml index 0a2909a7ed6..0d709625e7f 100644 --- a/examples/pom.xml +++ b/examples/pom.xml @@ -5,7 +5,7 @@ ca.uhn.hapi.fhir hapi-fhir - 1.6 + 2.0-SNAPSHOT ../pom.xml @@ -18,32 +18,32 @@ ca.uhn.hapi.fhir hapi-fhir-base - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-dstu2 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-dstu3 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-hl7org-dstu2 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-validation-resources-dstu2 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-jaxrsserver-base - 1.6 + 2.0-SNAPSHOT javax.servlet @@ -54,7 +54,7 @@ ca.uhn.hapi.fhir hapi-fhir-jaxrsserver-base - 1.6 + 2.0-SNAPSHOT javax.ws.rs diff --git a/hapi-deployable-pom/pom.xml b/hapi-deployable-pom/pom.xml index 1c6fd82c1f0..d12e3ba7d8a 100644 --- a/hapi-deployable-pom/pom.xml +++ b/hapi-deployable-pom/pom.xml @@ -4,7 +4,7 @@ ca.uhn.hapi.fhir hapi-fhir - 1.6 + 2.0-SNAPSHOT ../pom.xml diff --git a/hapi-fhir-android/pom.xml b/hapi-fhir-android/pom.xml index 6ce75370970..e3afc0a4db6 100644 --- a/hapi-fhir-android/pom.xml +++ b/hapi-fhir-android/pom.xml @@ -5,7 +5,7 @@ ca.uhn.hapi.fhir hapi-fhir - 1.6 + 2.0-SNAPSHOT ../pom.xml @@ -30,7 +30,7 @@ ca.uhn.hapi.fhir hapi-fhir-base - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-jpaserver-base - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-testpage-overlay - 1.6 + 2.0-SNAPSHOT war provided ca.uhn.hapi.fhir hapi-fhir-testpage-overlay - 1.6 + 2.0-SNAPSHOT classes provided diff --git a/hapi-fhir-cli/pom.xml b/hapi-fhir-cli/pom.xml index 18691cb78a7..1567dda2a37 100644 --- a/hapi-fhir-cli/pom.xml +++ b/hapi-fhir-cli/pom.xml @@ -5,7 +5,7 @@ ca.uhn.hapi.fhir hapi-fhir - 1.6 + 2.0-SNAPSHOT ../pom.xml diff --git a/hapi-fhir-cobertura/pom.xml b/hapi-fhir-cobertura/pom.xml index 333281946be..39ccb98db0d 100644 --- a/hapi-fhir-cobertura/pom.xml +++ b/hapi-fhir-cobertura/pom.xml @@ -6,7 +6,7 @@ ca.uhn.hapi.fhir hapi-deployable-pom - 1.6 + 2.0-SNAPSHOT ../hapi-deployable-pom/pom.xml @@ -19,42 +19,42 @@ ca.uhn.hapi.fhir hapi-fhir-base - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-dstu - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-dstu2 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-dstu3 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-hl7org-dstu2 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-validation-resources-dstu2 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-validation-resources-dstu3 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-jpaserver-base - 1.6 + 2.0-SNAPSHOT diff --git a/hapi-fhir-dist/pom.xml b/hapi-fhir-dist/pom.xml index f817f9578d8..7d4c95e7f43 100644 --- a/hapi-fhir-dist/pom.xml +++ b/hapi-fhir-dist/pom.xml @@ -5,7 +5,7 @@ ca.uhn.hapi.fhir hapi-fhir - 1.6 + 2.0-SNAPSHOT ../pom.xml @@ -18,49 +18,49 @@ ca.uhn.hapi.fhir hapi-fhir-base - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-dstu - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-dstu2 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-hl7org-dstu2 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-dstu3 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-validation-resources-dstu2 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-validation-resources-dstu3 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-cli-app - 1.6 + 2.0-SNAPSHOT provided ca.uhn.hapi.fhir hapi-fhir-android - 1.6 + 2.0-SNAPSHOT provided diff --git a/hapi-fhir-jacoco/pom.xml b/hapi-fhir-jacoco/pom.xml index 636b7d41d97..cbdd5361599 100644 --- a/hapi-fhir-jacoco/pom.xml +++ b/hapi-fhir-jacoco/pom.xml @@ -6,7 +6,7 @@ ca.uhn.hapi.fhir hapi-deployable-pom - 1.6 + 2.0-SNAPSHOT ../hapi-deployable-pom/pom.xml @@ -19,42 +19,42 @@ ca.uhn.hapi.fhir hapi-fhir-base - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-dstu - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-dstu2 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-dstu3 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-hl7org-dstu2 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-validation-resources-dstu2 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-validation-resources-dstu3 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-jpaserver-base - 1.6 + 2.0-SNAPSHOT diff --git a/hapi-fhir-jaxrsserver-base/pom.xml b/hapi-fhir-jaxrsserver-base/pom.xml index 03afaa1c27a..e094d1698aa 100644 --- a/hapi-fhir-jaxrsserver-base/pom.xml +++ b/hapi-fhir-jaxrsserver-base/pom.xml @@ -4,7 +4,7 @@ ca.uhn.hapi.fhir hapi-deployable-pom - 1.6 + 2.0-SNAPSHOT ../hapi-deployable-pom/pom.xml @@ -18,7 +18,7 @@ ca.uhn.hapi.fhir hapi-fhir-base - 1.6 + 2.0-SNAPSHOT commons-logging @@ -38,12 +38,12 @@ ca.uhn.hapi.fhir hapi-fhir-structures-dstu2 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-dstu3 - 1.6 + 2.0-SNAPSHOT diff --git a/hapi-fhir-jaxrsserver-example/pom.xml b/hapi-fhir-jaxrsserver-example/pom.xml index 36303e65247..f586f473c6d 100644 --- a/hapi-fhir-jaxrsserver-example/pom.xml +++ b/hapi-fhir-jaxrsserver-example/pom.xml @@ -6,7 +6,7 @@ ca.uhn.hapi.fhir hapi-fhir - 1.6 + 2.0-SNAPSHOT ../pom.xml @@ -31,7 +31,7 @@ ca.uhn.hapi.fhir hapi-fhir-jaxrsserver-base - 1.6 + 2.0-SNAPSHOT diff --git a/hapi-fhir-jpaserver-base/pom.xml b/hapi-fhir-jpaserver-base/pom.xml index 3dce684595d..a2c10dc4acb 100644 --- a/hapi-fhir-jpaserver-base/pom.xml +++ b/hapi-fhir-jpaserver-base/pom.xml @@ -4,7 +4,7 @@ ca.uhn.hapi.fhir hapi-deployable-pom - 1.6 + 2.0-SNAPSHOT ../hapi-deployable-pom/pom.xml @@ -36,7 +36,7 @@ ca.uhn.hapi.fhir hapi-fhir-base - 1.6 + 2.0-SNAPSHOT commons-logging @@ -47,32 +47,32 @@ ca.uhn.hapi.fhir hapi-fhir-structures-dstu - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-dstu2 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-dstu3 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-hl7org-dstu2 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-validation-resources-dstu2 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-validation-resources-dstu3 - 1.6 + 2.0-SNAPSHOT @@ -370,7 +370,7 @@ ca.uhn.hapi.fhir hapi-tinder-plugin - 1.6 + 2.0-SNAPSHOT build_dstu1 @@ -422,22 +422,22 @@ ca.uhn.hapi.fhir hapi-fhir-structures-dstu - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-dstu2 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-dstu3 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-validation-resources-dstu3 - 1.6 + 2.0-SNAPSHOT diff --git a/hapi-fhir-jpaserver-base/src/main/java/ca/uhn/fhir/jpa/dao/BaseHapiFhirResourceDao.java b/hapi-fhir-jpaserver-base/src/main/java/ca/uhn/fhir/jpa/dao/BaseHapiFhirResourceDao.java index dc1a608192e..29fbbd49ed9 100644 --- a/hapi-fhir-jpaserver-base/src/main/java/ca/uhn/fhir/jpa/dao/BaseHapiFhirResourceDao.java +++ b/hapi-fhir-jpaserver-base/src/main/java/ca/uhn/fhir/jpa/dao/BaseHapiFhirResourceDao.java @@ -97,13 +97,10 @@ public abstract class BaseHapiFhirResourceDao extends B @Autowired private DaoConfig myDaoConfig; - @Autowired protected PlatformTransactionManager myPlatformTransactionManager; - @Autowired private IResourceHistoryTableDao myResourceHistoryTableDao; - @Autowired() protected IResourceIndexedSearchParamUriDao myResourceIndexedSearchParamUriDao; private String myResourceName; @@ -112,9 +109,7 @@ public abstract class BaseHapiFhirResourceDao extends B protected IFulltextSearchSvc mySearchDao; @Autowired() protected ISearchResultDao mySearchResultDao; - private String mySecondaryPrimaryKeyParamName; - @Autowired() protected IHapiTerminologySvc myTerminologySvc; @@ -147,11 +142,21 @@ public abstract class BaseHapiFhirResourceDao extends B ourLog.info("Processed addTag {}/{} on {} in {}ms", new Object[] { theScheme, theTerm, theId, w.getMillisAndRestart() }); } + @Override + public DaoMethodOutcome create(final T theResource) { + return create(theResource, null, true, null); + } + @Override public DaoMethodOutcome create(final T theResource, RequestDetails theRequestDetails) { return create(theResource, null, true, theRequestDetails); } + @Override + public DaoMethodOutcome create(final T theResource, String theIfNoneExist) { + return create(theResource, theIfNoneExist, null); + } + @Override public DaoMethodOutcome create(T theResource, String theIfNoneExist, boolean thePerformIndexing, RequestDetails theRequestDetails) { if (isNotBlank(theResource.getIdElement().getIdPart())) { @@ -201,7 +206,7 @@ public abstract class BaseHapiFhirResourceDao extends B ActionRequestDetails requestDetails = new ActionRequestDetails(theRequestDetails, getContext(), theId.getResourceType(), theId); notifyInterceptors(RestOperationTypeEnum.DELETE, requestDetails); } - + Date updateTime = new Date(); ResourceTable savedEntity = updateEntity(null, entity, updateTime, updateTime); @@ -216,10 +221,15 @@ public abstract class BaseHapiFhirResourceDao extends B } } } - + return savedEntity; } + @Override + public DaoMethodOutcome delete(IIdType theId) { + return delete(theId, null); + } + @Override public DaoMethodOutcome delete(IIdType theId, RequestDetails theRequestDetails) { List deleteConflicts = new ArrayList(); @@ -332,7 +342,7 @@ public abstract class BaseHapiFhirResourceDao extends B ActionRequestDetails requestDetails = new ActionRequestDetails(theRequestDetails, getContext(), theResource); notifyInterceptors(RestOperationTypeEnum.CREATE, requestDetails); } - + // Perform actual DB update updateEntity(theResource, entity, null, thePerformIndexing, true, theUpdateTime); theResource.setId(entity.getIdDt()); @@ -347,7 +357,7 @@ public abstract class BaseHapiFhirResourceDao extends B } } } - + DaoMethodOutcome outcome = toMethodOutcome(entity, theResource).setCreated(true); String msg = getContext().getLocalizer().getMessage(BaseHapiFhirResourceDao.class, "successfulCreate", outcome.getId(), w.getMillisAndRestart()); @@ -473,6 +483,36 @@ public abstract class BaseHapiFhirResourceDao extends B return retVal; } + @Override + public MT metaAddOperation(IIdType theResourceId, MT theMetaAdd, RequestDetails theRequestDetails) { + // Notify interceptors + ActionRequestDetails requestDetails = new ActionRequestDetails(theRequestDetails, getResourceName(), theResourceId); + notifyInterceptors(RestOperationTypeEnum.META_ADD, requestDetails); + + StopWatch w = new StopWatch(); + BaseHasResource entity = readEntity(theResourceId); + if (entity == null) { + throw new ResourceNotFoundException(theResourceId); + } + + ResourceTable latestVersion = readEntityLatestVersion(theResourceId); + if (latestVersion.getVersion() != entity.getVersion()) { + doMetaAdd(theMetaAdd, entity); + } else { + doMetaAdd(theMetaAdd, latestVersion); + + // Also update history entry + ResourceHistoryTable history = myResourceHistoryTableDao.findForIdAndVersion(entity.getId(), entity.getVersion()); + doMetaAdd(theMetaAdd, history); + } + + ourLog.info("Processed metaAddOperation on {} in {}ms", new Object[] { theResourceId, w.getMillisAndRestart() }); + + @SuppressWarnings("unchecked") + MT retVal = (MT) metaGetOperation(theMetaAdd.getClass(), theResourceId, theRequestDetails); + return retVal; + } + // @Override // public IBundleProvider everything(IIdType theId) { // Search search = new Search(); @@ -555,36 +595,6 @@ public abstract class BaseHapiFhirResourceDao extends B // }; // } - @Override - public MT metaAddOperation(IIdType theResourceId, MT theMetaAdd, RequestDetails theRequestDetails) { - // Notify interceptors - ActionRequestDetails requestDetails = new ActionRequestDetails(theRequestDetails, getResourceName(), theResourceId); - notifyInterceptors(RestOperationTypeEnum.META_ADD, requestDetails); - - StopWatch w = new StopWatch(); - BaseHasResource entity = readEntity(theResourceId); - if (entity == null) { - throw new ResourceNotFoundException(theResourceId); - } - - ResourceTable latestVersion = readEntityLatestVersion(theResourceId); - if (latestVersion.getVersion() != entity.getVersion()) { - doMetaAdd(theMetaAdd, entity); - } else { - doMetaAdd(theMetaAdd, latestVersion); - - // Also update history entry - ResourceHistoryTable history = myResourceHistoryTableDao.findForIdAndVersion(entity.getId(), entity.getVersion()); - doMetaAdd(theMetaAdd, history); - } - - ourLog.info("Processed metaAddOperation on {} in {}ms", new Object[] { theResourceId, w.getMillisAndRestart() }); - - @SuppressWarnings("unchecked") - MT retVal = (MT) metaGetOperation(theMetaAdd.getClass(), theResourceId, theRequestDetails); - return retVal; - } - @Override public MT metaDeleteOperation(IIdType theResourceId, MT theMetaDel, RequestDetails theRequestDetails) { // Notify interceptors @@ -710,6 +720,11 @@ public abstract class BaseHapiFhirResourceDao extends B return processMatchUrl(theMatchUrl, getResourceType()); } + @Override + public T read(IIdType theId) { + return read(theId, null); + } + @Override public T read(IIdType theId, RequestDetails theRequestDetails) { validateResourceTypeAndThrowIllegalArgumentException(theId); @@ -720,7 +735,7 @@ public abstract class BaseHapiFhirResourceDao extends B RestOperationTypeEnum operationType = theId.hasVersionIdPart() ? RestOperationTypeEnum.VREAD : RestOperationTypeEnum.READ; notifyInterceptors(operationType, requestDetails); } - + StopWatch w = new StopWatch(); BaseHasResource entity = readEntity(theId); validateResourceType(entity); @@ -970,6 +985,11 @@ public abstract class BaseHapiFhirResourceDao extends B return retVal; } + @Override + public DaoMethodOutcome update(T theResource) { + return update(theResource, null, null); + } + @Override public DaoMethodOutcome update(T theResource, RequestDetails theRequestDetails) { return update(theResource, null, theRequestDetails); @@ -1023,17 +1043,22 @@ public abstract class BaseHapiFhirResourceDao extends B } // Notify interceptors - ActionRequestDetails requestDetails = new ActionRequestDetails(theRequestDetails, theResource, getResourceName(), resourceId); - notifyInterceptors(RestOperationTypeEnum.UPDATE, requestDetails); + ActionRequestDetails requestDetails = null; + if (theRequestDetails != null) { + requestDetails = new ActionRequestDetails(theRequestDetails, theResource, getResourceName(), resourceId); + notifyInterceptors(RestOperationTypeEnum.UPDATE, requestDetails); + } // Perform update ResourceTable savedEntity = updateEntity(theResource, entity, null, thePerformIndexing, true, new Date()); // Notify interceptors - theRequestDetails.getRequestOperationCallback().resourceUpdated(theResource); - for (IServerInterceptor next : getConfig().getInterceptors()) { - if (next instanceof IJpaServerInterceptor) { - ((IJpaServerInterceptor) next).resourceUpdated(requestDetails, entity); + if (theRequestDetails != null) { + theRequestDetails.getRequestOperationCallback().resourceUpdated(theResource); + for (IServerInterceptor next : getConfig().getInterceptors()) { + if (next instanceof IJpaServerInterceptor) { + ((IJpaServerInterceptor) next).resourceUpdated(requestDetails, entity); + } } } @@ -1046,6 +1071,11 @@ public abstract class BaseHapiFhirResourceDao extends B return outcome; } + @Override + public DaoMethodOutcome update(T theResource, String theMatchUrl) { + return update(theResource, theMatchUrl, null); + } + @Override public DaoMethodOutcome update(T theResource, String theMatchUrl, RequestDetails theRequestDetails) { return update(theResource, theMatchUrl, true, theRequestDetails); diff --git a/hapi-fhir-jpaserver-base/src/main/java/ca/uhn/fhir/jpa/dao/IFhirResourceDao.java b/hapi-fhir-jpaserver-base/src/main/java/ca/uhn/fhir/jpa/dao/IFhirResourceDao.java index dd44dfc8818..3ef1d9737dc 100644 --- a/hapi-fhir-jpaserver-base/src/main/java/ca/uhn/fhir/jpa/dao/IFhirResourceDao.java +++ b/hapi-fhir-jpaserver-base/src/main/java/ca/uhn/fhir/jpa/dao/IFhirResourceDao.java @@ -46,9 +46,19 @@ public interface IFhirResourceDao extends IDao { void addTag(IIdType theId, TagTypeEnum theTagType, String theScheme, String theTerm, String theLabel); + /** + * Create a resource - Note that this variant of the method does not take in a {@link RequestDetails} and + * therefore can not fire any interceptors. Use only for internal system calls + */ + DaoMethodOutcome create(T theResource); + DaoMethodOutcome create(T theResource, RequestDetails theRequestDetails); - DaoMethodOutcome create(T theResource, String theIfNoneExist, RequestDetails theRequestDetails); + /** + * Create a resource - Note that this variant of the method does not take in a {@link RequestDetails} and + * therefore can not fire any interceptors. Use only for internal system calls + */ + DaoMethodOutcome create(T theResource, String theIfNoneExist); /** * @param thePerformIndexing @@ -58,11 +68,13 @@ public interface IFhirResourceDao extends IDao { */ DaoMethodOutcome create(T theResource, String theIfNoneExist, boolean thePerformIndexing, RequestDetails theRequestDetails); + DaoMethodOutcome create(T theResource, String theIfNoneExist, RequestDetails theRequestDetails); + /** - * This method throws an exception if there are delete conflicts - * @param theRequestDetails TODO + * Delete a resource - Note that this variant of the method does not take in a {@link RequestDetails} and + * therefore can not fire any interceptors. Use only for internal system calls */ - DaoMethodOutcome delete(IIdType theResource, RequestDetails theRequestDetails); + DaoMethodOutcome delete(IIdType theResource); /** * This method does not throw an exception if there are delete conflicts, but populates them @@ -73,18 +85,20 @@ public interface IFhirResourceDao extends IDao { /** * This method throws an exception if there are delete conflicts - * @param theRequestDetails TODO */ - DaoMethodOutcome deleteByUrl(String theString, RequestDetails theRequestDetails); + DaoMethodOutcome delete(IIdType theResource, RequestDetails theRequestDetails); /** * This method does not throw an exception if there are delete conflicts, but populates them * in the provided list - * @param theRequestDetails TODO - * @return */ List deleteByUrl(String theUrl, List theDeleteConflictsListToPopulate, RequestDetails theRequestDetails); + /** + * This method throws an exception if there are delete conflicts + */ + DaoMethodOutcome deleteByUrl(String theString, RequestDetails theRequestDetails); + TagList getAllResourceTags(RequestDetails theRequestDetails); Class getResourceType(); @@ -111,16 +125,22 @@ public interface IFhirResourceDao extends IDao { * Not supported in DSTU1! * @param theRequestDetails TODO */ - MT metaGetOperation(Class theType, RequestDetails theRequestDetails); + MT metaGetOperation(Class theType, IIdType theId, RequestDetails theRequestDetails); /** * Not supported in DSTU1! * @param theRequestDetails TODO */ - MT metaGetOperation(Class theType, IIdType theId, RequestDetails theRequestDetails); + MT metaGetOperation(Class theType, RequestDetails theRequestDetails); Set processMatchUrl(String theMatchUrl); + /** + * Read a resource - Note that this variant of the method does not take in a {@link RequestDetails} and + * therefore can not fire any interceptors. Use only for internal system calls + */ + T read(IIdType theId); + /** * * @param theId @@ -160,9 +180,19 @@ public interface IFhirResourceDao extends IDao { Set searchForIdsWithAndOr(SearchParameterMap theParams); + /** + * Update a resource - Note that this variant of the method does not take in a {@link RequestDetails} and + * therefore can not fire any interceptors. Use only for internal system calls + */ + DaoMethodOutcome update(T theResource); + DaoMethodOutcome update(T theResource, RequestDetails theRequestDetails); - DaoMethodOutcome update(T theResource, String theMatchUrl, RequestDetails theRequestDetails); + /** + * Update a resource - Note that this variant of the method does not take in a {@link RequestDetails} and + * therefore can not fire any interceptors. Use only for internal system calls + */ + DaoMethodOutcome update(T theResource, String theMatchUrl); /** * @param thePerformIndexing @@ -172,6 +202,8 @@ public interface IFhirResourceDao extends IDao { */ DaoMethodOutcome update(T theResource, String theMatchUrl, boolean thePerformIndexing, RequestDetails theRequestDetails); + DaoMethodOutcome update(T theResource, String theMatchUrl, RequestDetails theRequestDetails); + /** * Not supported in DSTU1! * @param theRequestDetails TODO diff --git a/hapi-fhir-jpaserver-base/src/main/java/ca/uhn/fhir/jpa/subscription/SubscriptionWebsocketHandlerDstu2.java b/hapi-fhir-jpaserver-base/src/main/java/ca/uhn/fhir/jpa/subscription/SubscriptionWebsocketHandlerDstu2.java index 5acbf713d8d..54b32de78b2 100644 --- a/hapi-fhir-jpaserver-base/src/main/java/ca/uhn/fhir/jpa/subscription/SubscriptionWebsocketHandlerDstu2.java +++ b/hapi-fhir-jpaserver-base/src/main/java/ca/uhn/fhir/jpa/subscription/SubscriptionWebsocketHandlerDstu2.java @@ -270,7 +270,7 @@ public class SubscriptionWebsocketHandlerDstu2 extends TextWebSocketHandler impl } } - IIdType id = mySubscriptionDao.create(subscription, null).getId(); + IIdType id = mySubscriptionDao.create(subscription).getId(); mySubscriptionPid = mySubscriptionDao.getSubscriptionTablePidForSubscriptionResource(id); mySubscriptionId = subscription.getIdElement(); diff --git a/hapi-fhir-jpaserver-base/src/main/java/ca/uhn/fhir/jpa/subscription/SubscriptionWebsocketHandlerDstu3.java b/hapi-fhir-jpaserver-base/src/main/java/ca/uhn/fhir/jpa/subscription/SubscriptionWebsocketHandlerDstu3.java index 459a1736f0a..bddb1af9cfc 100644 --- a/hapi-fhir-jpaserver-base/src/main/java/ca/uhn/fhir/jpa/subscription/SubscriptionWebsocketHandlerDstu3.java +++ b/hapi-fhir-jpaserver-base/src/main/java/ca/uhn/fhir/jpa/subscription/SubscriptionWebsocketHandlerDstu3.java @@ -270,7 +270,7 @@ public class SubscriptionWebsocketHandlerDstu3 extends TextWebSocketHandler impl } } - IIdType id = mySubscriptionDao.create(subscription, null).getId(); + IIdType id = mySubscriptionDao.create(subscription).getId(); mySubscriptionPid = mySubscriptionDao.getSubscriptionTablePidForSubscriptionResource(id); mySubscriptionId = subscription.getIdElement(); diff --git a/hapi-fhir-jpaserver-base/src/test/java/ca/uhn/fhir/jpa/dao/dstu3/FhirResourceDaoDstu3UpdateTest.java b/hapi-fhir-jpaserver-base/src/test/java/ca/uhn/fhir/jpa/dao/dstu3/FhirResourceDaoDstu3UpdateTest.java index 3ed2e4c6c13..447bf7c0f85 100644 --- a/hapi-fhir-jpaserver-base/src/test/java/ca/uhn/fhir/jpa/dao/dstu3/FhirResourceDaoDstu3UpdateTest.java +++ b/hapi-fhir-jpaserver-base/src/test/java/ca/uhn/fhir/jpa/dao/dstu3/FhirResourceDaoDstu3UpdateTest.java @@ -43,6 +43,7 @@ import ca.uhn.fhir.rest.api.RestOperationTypeEnum; import ca.uhn.fhir.rest.param.StringParam; import ca.uhn.fhir.rest.server.IBundleProvider; import ca.uhn.fhir.rest.server.exceptions.InvalidRequestException; +import ca.uhn.fhir.rest.server.exceptions.ResourceGoneException; import ca.uhn.fhir.rest.server.exceptions.UnprocessableEntityException; import ca.uhn.fhir.rest.server.interceptor.IServerInterceptor.ActionRequestDetails; import ca.uhn.fhir.rest.server.servlet.ServletRequestDetails; @@ -151,6 +152,46 @@ public class FhirResourceDaoDstu3UpdateTest extends BaseJpaDstu3Test { } + @Test + public void testCreateAndUpdateWithoutRequest() throws Exception { + String methodName = "testUpdateByUrl"; + + Patient p = new Patient(); + p.addIdentifier().setSystem("urn:system").setValue(methodName + "2"); + IIdType id = myPatientDao.create(p).getId().toUnqualified(); + + p = new Patient(); + p.addIdentifier().setSystem("urn:system").setValue(methodName + "2"); + IIdType id2 = myPatientDao.create(p, "Patient?identifier=urn:system|" + methodName + "2").getId().toUnqualified(); + assertEquals(id.getValue(), id2.getValue()); + + p = new Patient(); + p.setId(id); + p.addIdentifier().setSystem("urn:system").setValue(methodName + "2"); + myPatientDao.update(p).getId(); + + id2 = myPatientDao.update(p, "Patient?identifier=urn:system|" + methodName + "2").getId().toUnqualified(); + assertEquals(id.getIdPart(), id2.getIdPart()); + assertEquals("3", id2.getVersionIdPart()); + + Patient newPatient = myPatientDao.read(id); + assertEquals("1", newPatient.getIdElement().getVersionIdPart()); + + newPatient = myPatientDao.read(id.toVersionless()); + assertEquals("3", newPatient.getIdElement().getVersionIdPart()); + + myPatientDao.delete(id.toVersionless()); + + try { + myPatientDao.read(id.toVersionless()); + fail(); + } catch (ResourceGoneException e) { + // nothing + } + + } + + @Test public void testUpdateConditionalByLastUpdated() throws Exception { String methodName = "testUpdateByUrl"; diff --git a/hapi-fhir-jpaserver-base/src/test/java/ca/uhn/fhir/jpa/provider/dstu3/ResourceProviderDstu3Test.java b/hapi-fhir-jpaserver-base/src/test/java/ca/uhn/fhir/jpa/provider/dstu3/ResourceProviderDstu3Test.java index f5e2739f926..76948f34e59 100644 --- a/hapi-fhir-jpaserver-base/src/test/java/ca/uhn/fhir/jpa/provider/dstu3/ResourceProviderDstu3Test.java +++ b/hapi-fhir-jpaserver-base/src/test/java/ca/uhn/fhir/jpa/provider/dstu3/ResourceProviderDstu3Test.java @@ -173,6 +173,7 @@ public class ResourceProviderDstu3Test extends BaseResourceProviderDstu3Test { for (int i = 0; i < 10; i++) { Thread.sleep(100); preDates.add(new Date()); + Thread.sleep(100); patient.setId(id); patient.getName().get(0).getFamily().get(0).setValue(methodName + "_i"); ids.add(myPatientDao.update(patient, mySrd).getId().toUnqualified().getValue()); diff --git a/hapi-fhir-jpaserver-example/pom.xml b/hapi-fhir-jpaserver-example/pom.xml index d89ab64e181..5751a39978e 100644 --- a/hapi-fhir-jpaserver-example/pom.xml +++ b/hapi-fhir-jpaserver-example/pom.xml @@ -6,7 +6,7 @@ ca.uhn.hapi.fhir hapi-fhir - 1.6 + 2.0-SNAPSHOT ../pom.xml @@ -31,40 +31,40 @@ ca.uhn.hapi.fhir hapi-fhir-base - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-dstu - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-dstu2 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-jpaserver-base - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-testpage-overlay - 1.6 + 2.0-SNAPSHOT war provided ca.uhn.hapi.fhir hapi-fhir-testpage-overlay - 1.6 + 2.0-SNAPSHOT classes provided diff --git a/hapi-fhir-jpaserver-uhnfhirtest/pom.xml b/hapi-fhir-jpaserver-uhnfhirtest/pom.xml index 6fd1f9d1ada..b78f0146e5b 100644 --- a/hapi-fhir-jpaserver-uhnfhirtest/pom.xml +++ b/hapi-fhir-jpaserver-uhnfhirtest/pom.xml @@ -5,7 +5,7 @@ ca.uhn.hapi.fhir hapi-fhir - 1.6 + 2.0-SNAPSHOT ../pom.xml @@ -18,34 +18,34 @@ ca.uhn.hapi.fhir hapi-fhir-jpaserver-base - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-dstu - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-dstu2 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-hl7org-dstu2 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-testpage-overlay - 1.6 + 2.0-SNAPSHOT war provided ca.uhn.hapi.fhir hapi-fhir-testpage-overlay - 1.6 + 2.0-SNAPSHOT classes provided @@ -178,7 +178,6 @@ / true - diff --git a/hapi-fhir-osgi-core/pom.xml b/hapi-fhir-osgi-core/pom.xml index c63082a1f4f..71ebf9d344b 100644 --- a/hapi-fhir-osgi-core/pom.xml +++ b/hapi-fhir-osgi-core/pom.xml @@ -4,7 +4,7 @@ ca.uhn.hapi.fhir hapi-deployable-pom - 1.6 + 2.0-SNAPSHOT ../hapi-deployable-pom/pom.xml @@ -19,37 +19,37 @@ ca.uhn.hapi.fhir hapi-fhir-base - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-dstu - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-dstu2 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-hl7org-dstu2 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-dstu3 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-validation-resources-dstu2 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-validation-resources-dstu3 - 1.6 + 2.0-SNAPSHOT diff --git a/hapi-fhir-structures-dstu/pom.xml b/hapi-fhir-structures-dstu/pom.xml index f4abb5576cb..994594b2b2e 100644 --- a/hapi-fhir-structures-dstu/pom.xml +++ b/hapi-fhir-structures-dstu/pom.xml @@ -4,7 +4,7 @@ ca.uhn.hapi.fhir hapi-deployable-pom - 1.6 + 2.0-SNAPSHOT ../hapi-deployable-pom/pom.xml @@ -17,7 +17,7 @@ ca.uhn.hapi.fhir hapi-fhir-base - 1.6 + 2.0-SNAPSHOT diff --git a/hapi-fhir-validation-resources-dstu2/pom.xml b/hapi-fhir-validation-resources-dstu2/pom.xml index acbe2c408d2..fbb6ce9ed55 100644 --- a/hapi-fhir-validation-resources-dstu2/pom.xml +++ b/hapi-fhir-validation-resources-dstu2/pom.xml @@ -4,7 +4,7 @@ ca.uhn.hapi.fhir hapi-deployable-pom - 1.6 + 2.0-SNAPSHOT ../hapi-deployable-pom/pom.xml diff --git a/hapi-fhir-validation-resources-dstu3/pom.xml b/hapi-fhir-validation-resources-dstu3/pom.xml index 28e3cdaf60b..7827cbb09ad 100644 --- a/hapi-fhir-validation-resources-dstu3/pom.xml +++ b/hapi-fhir-validation-resources-dstu3/pom.xml @@ -4,7 +4,7 @@ ca.uhn.hapi.fhir hapi-deployable-pom - 1.6 + 2.0-SNAPSHOT ../hapi-deployable-pom/pom.xml @@ -17,7 +17,7 @@ ca.uhn.hapi.fhir hapi-fhir-base - 1.6 + 2.0-SNAPSHOT ch.qos.logback diff --git a/hapi-tinder-plugin/pom.xml b/hapi-tinder-plugin/pom.xml index 15e4a6b0c4b..fe979afd347 100644 --- a/hapi-tinder-plugin/pom.xml +++ b/hapi-tinder-plugin/pom.xml @@ -5,7 +5,7 @@ ca.uhn.hapi.fhir hapi-fhir - 1.6 + 2.0-SNAPSHOT ../pom.xml @@ -19,7 +19,7 @@ ca.uhn.hapi.fhir hapi-fhir-base - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-structures-dstu2 - 1.6 + 2.0-SNAPSHOT ca.uhn.hapi.fhir hapi-fhir-testpage-overlay - 1.6 + 2.0-SNAPSHOT war provided ca.uhn.hapi.fhir hapi-fhir-testpage-overlay - 1.6 + 2.0-SNAPSHOT classes provided diff --git a/src/changes/changes.xml b/src/changes/changes.xml index 43fbb4ed4da..44d83509538 100644 --- a/src/changes/changes.xml +++ b/src/changes/changes.xml @@ -6,6 +6,16 @@ HAPI FHIR Changelog + + + Fix issue in DSTU1 Bundle parsing where unexpected elements in the bundle resulted in a failure + to parse. + + + DSTU2 QuestionnaireResponse validator failed with an exception if the + QuestionnaireResponse contained certain groups with no content + + Performance has been improved for the initial FhirContext diff --git a/src/site/xdoc/download.xml.vm b/src/site/xdoc/download.xml.vm index 93880bbf7f7..792e5ed9499 100644 --- a/src/site/xdoc/download.xml.vm +++ b/src/site/xdoc/download.xml.vm @@ -20,7 +20,7 @@ hapi-fhir-structures-dstu - 1.1 - 1.6 + 1.1 - 1.6.1 DSTU1 0.0.82 @@ -33,7 +33,7 @@ DSTU2 1.0.0 - 1.3 - 1.6 + 1.3 - 1.6.1 DSTU2 1.0.2 @@ -50,7 +50,7 @@ DSTU2 1.0.2 - hapi-fhir-structures-dstu3 + hapi-fhir-structures-dstu3 1.4 DSTU3 1.3.0 Snapshot (SVN 7602) @@ -62,6 +62,10 @@ 1.6 DSTU3 1.4.0 Snapshot (SVN 8636) + + 1.6.1 + DSTU3 1.5.0 Snapshot (SVN 8636) + diff --git a/src/site/xdoc/index.xml b/src/site/xdoc/index.xml index 3726243fa98..da050de4c42 100644 --- a/src/site/xdoc/index.xml +++ b/src/site/xdoc/index.xml @@ -71,7 +71,7 @@ of changes in this version. Among the enhancements in this release are:

    -
  • Significant enhancements to FhirConetxt startup performance (especially on Android)
  • +
  • Significant enhancements to FhirContext startup performance (especially on Android)
  • Support for STU3 terminology services in the JPA module, including support for importing SNOMED CT and LOINC
  • Update of the STU3 resources and validator to the latest snapshot
  • Plenty of bug fixes