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.svc;
021
022/**
023 * Resolution mode parameter for methods on {@link IIdHelperService}
024 */
025public class ResolveIdentityMode {
026
027        private final boolean myIncludeDeleted;
028        private final boolean myUseCache;
029        private final boolean myFailOnDeleted;
030
031        /**
032         * Non-instantiable. Use the factory methods on this class.
033         */
034        private ResolveIdentityMode(boolean theIncludeDeleted, boolean theFailOnDeleted, boolean theUseCache) {
035                myIncludeDeleted = theIncludeDeleted;
036                myUseCache = theUseCache;
037                myFailOnDeleted = theFailOnDeleted;
038        }
039
040        public boolean isUseCache(boolean theDeleteEnabled) {
041                if (myUseCache) {
042                        return true;
043                } else {
044                        return !theDeleteEnabled;
045                }
046        }
047
048        public boolean isIncludeDeleted() {
049                return myIncludeDeleted;
050        }
051
052        public boolean isFailOnDeleted() {
053                return myFailOnDeleted;
054        }
055
056        /**
057         * Deleted resource identities can be included in the results
058         */
059        public static Builder includeDeleted() {
060                return new Builder(true, false);
061        }
062
063        /**
064         * Deleted resource identities should be excluded from the results
065         */
066        public static Builder excludeDeleted() {
067                return new Builder(false, false);
068        }
069
070        /**
071         * Throw a {@link ca.uhn.fhir.rest.server.exceptions.ResourceGoneException} if
072         * any of the supplied IDs corresponds to a deleted resource
073         */
074        public static Builder failOnDeleted() {
075                return new Builder(false, true);
076        }
077
078        public static class Builder {
079
080                private final boolean myIncludeDeleted;
081                private final boolean myFailOnDeleted;
082
083                private Builder(boolean theIncludeDeleted, boolean theFailOnDeleted) {
084                        myIncludeDeleted = theIncludeDeleted;
085                        myFailOnDeleted = theFailOnDeleted;
086                }
087
088                /**
089                 * Cached results are acceptable. This mode is obviously more efficient since it'll always
090                 * try the cache first, but it should not be used in cases where it matters whether the
091                 * deleted status has changed for a resource.
092                 */
093                public ResolveIdentityMode cacheOk() {
094                        return new ResolveIdentityMode(myIncludeDeleted, myFailOnDeleted, true);
095                }
096
097                /**
098                 * In this mode, the cache won't be used unless deletes are disabled on this server
099                 * (meaning that the deleted status of a resource is not able to change)
100                 */
101                public ResolveIdentityMode noCacheUnlessDeletesDisabled() {
102                        return new ResolveIdentityMode(myIncludeDeleted, myFailOnDeleted, false);
103                }
104        }
105}