001/*
002 * #%L
003 * HAPI FHIR Storage api
004 * %%
005 * Copyright (C) 2014 - 2025 Smile CDR, Inc.
006 * %%
007 * Licensed under the Apache License, Version 2.0 (the "License");
008 * you may not use this file except in compliance with the License.
009 * You may obtain a copy of the License at
010 *
011 *      http://www.apache.org/licenses/LICENSE-2.0
012 *
013 * Unless required by applicable law or agreed to in writing, software
014 * distributed under the License is distributed on an "AS IS" BASIS,
015 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
016 * See the License for the specific language governing permissions and
017 * limitations under the License.
018 * #L%
019 */
020package ca.uhn.fhir.jpa.api.model;
021
022import ca.uhn.fhir.jpa.model.cross.IBasePersistedResource;
023import ca.uhn.fhir.rest.api.MethodOutcome;
024import ca.uhn.fhir.rest.api.RestOperationTypeEnum;
025import ca.uhn.fhir.rest.api.server.storage.IResourcePersistentId;
026import org.hl7.fhir.instance.model.api.IBaseResource;
027
028public class DaoMethodOutcome extends MethodOutcome {
029
030        private IBasePersistedResource myEntity;
031        private IBaseResource myPreviousResource;
032        private boolean myNop;
033        private IResourcePersistentId myResourcePersistentId;
034        private RestOperationTypeEnum myOperationType;
035        private String myMatchUrl;
036
037        /**
038         * Constructor
039         */
040        public DaoMethodOutcome() {
041                super();
042        }
043
044        public RestOperationTypeEnum getOperationType() {
045                return myOperationType;
046        }
047
048        public void setOperationType(RestOperationTypeEnum theOperationType) {
049                myOperationType = theOperationType;
050        }
051
052        public String getMatchUrl() {
053                return myMatchUrl;
054        }
055
056        public void setMatchUrl(String theMatchUrl) {
057                myMatchUrl = theMatchUrl;
058        }
059
060        /**
061         * Was this a NO-OP - Typically because of an update to a resource that already matched the contents provided
062         */
063        public boolean isNop() {
064                return myNop;
065        }
066
067        /**
068         * Was this a NO-OP - Typically because of an update to a resource that already matched the contents provided
069         */
070        public DaoMethodOutcome setNop(boolean theNop) {
071                myNop = theNop;
072                return this;
073        }
074
075        public IBasePersistedResource getEntity() {
076                return myEntity;
077        }
078
079        public DaoMethodOutcome setEntity(IBasePersistedResource theEntity) {
080                myEntity = theEntity;
081                return this;
082        }
083
084        /**
085         * For update operations, this is the body of the resource as it was before the
086         * update
087         */
088        public IBaseResource getPreviousResource() {
089                return myPreviousResource;
090        }
091
092        /**
093         * For update operations, this is the body of the resource as it was before the
094         * update
095         */
096        public void setPreviousResource(IBaseResource thePreviousResource) {
097                myPreviousResource = thePreviousResource;
098        }
099
100        @Override
101        public DaoMethodOutcome setCreated(Boolean theCreated) {
102                super.setCreated(theCreated);
103                return this;
104        }
105
106        public IResourcePersistentId getPersistentId() {
107                return myResourcePersistentId;
108        }
109
110        public DaoMethodOutcome setPersistentId(IResourcePersistentId theResourcePersistentId) {
111                myResourcePersistentId = theResourcePersistentId;
112                return this;
113        }
114}