001/*
002 * #%L
003 * HAPI FHIR - Core Library
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.rest.server.exceptions;
021
022import ca.uhn.fhir.model.base.composite.BaseIdentifierDt;
023import ca.uhn.fhir.rest.api.Constants;
024import ca.uhn.fhir.util.CoverageIgnore;
025import org.hl7.fhir.instance.model.api.IBaseOperationOutcome;
026import org.hl7.fhir.instance.model.api.IBaseResource;
027import org.hl7.fhir.instance.model.api.IIdType;
028
029/**
030 * Represents an <b>HTTP 410 Resource Gone</b> response, which geenerally
031 * indicates that the resource has been deleted
032 */
033@CoverageIgnore
034public class ResourceGoneException extends BaseServerResponseException {
035
036        public static final int STATUS_CODE = Constants.STATUS_HTTP_410_GONE;
037        private static final long serialVersionUID = 1L;
038        private IIdType myResourceId;
039
040        /**
041         * Constructor which creates an error message based on a given resource ID
042         *
043         * @param theResourceId The ID of the resource that could not be found
044         */
045        public ResourceGoneException(IIdType theResourceId) {
046                super(STATUS_CODE, "Resource " + (theResourceId != null ? theResourceId.getValue() : "") + " is gone/deleted");
047                myResourceId = theResourceId;
048        }
049
050        /**
051         * @deprecated This constructor has a dependency on a specific model version and will be removed. Deprecated in HAPI
052         * 1.6 - 2016-07-02
053         */
054        @Deprecated
055        public ResourceGoneException(Class<? extends IBaseResource> theClass, BaseIdentifierDt thePatientId) {
056                super(
057                                STATUS_CODE,
058                                "Resource of type " + theClass.getSimpleName() + " with ID " + thePatientId + " is gone/deleted");
059                myResourceId = null;
060        }
061
062        /**
063         * Constructor which creates an error message based on a given resource ID
064         *
065         * @param theClass      The type of resource that could not be found
066         * @param theResourceId The ID of the resource that could not be found
067         */
068        public ResourceGoneException(Class<? extends IBaseResource> theClass, IIdType theResourceId) {
069                super(
070                                STATUS_CODE,
071                                "Resource of type " + theClass.getSimpleName() + " with ID " + theResourceId + " is gone/deleted");
072                myResourceId = theResourceId;
073        }
074
075        /**
076         * Constructor
077         *
078         * @param theMessage          The message
079         * @param theOperationOutcome The OperationOutcome resource to return to the client
080         */
081        public ResourceGoneException(String theMessage, IBaseOperationOutcome theOperationOutcome) {
082                super(STATUS_CODE, theMessage, theOperationOutcome);
083        }
084
085        /**
086         * Constructor
087         *
088         * @param theMessage The message
089         */
090        public ResourceGoneException(String theMessage) {
091                super(STATUS_CODE, theMessage);
092        }
093
094        public IIdType getResourceId() {
095                return myResourceId;
096        }
097
098        public void setResourceId(IIdType theResourceId) {
099                myResourceId = theResourceId;
100        }
101}