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.dao;
021
022import ca.uhn.fhir.model.api.annotation.Description;
023import ca.uhn.fhir.rest.api.SortSpec;
024import ca.uhn.fhir.rest.param.DateRangeParam;
025import ca.uhn.fhir.rest.param.StringAndListParam;
026import org.hl7.fhir.instance.model.api.IPrimitiveType;
027
028public final class PatientEverythingParameters {
029        @Description(
030                        formalDefinition =
031                                        "Results from this method are returned across multiple pages. This parameter controls the size of those pages.")
032        private IPrimitiveType<Integer> myCount;
033
034        @Description(
035                        formalDefinition =
036                                        "Results from this method are returned across multiple pages. This parameter controls the offset when fetching a page.")
037        private IPrimitiveType<Integer> myOffset;
038
039        @Description(shortDefinition = "Only return resources which were last updated as specified by the given range")
040        private DateRangeParam myLastUpdated;
041
042        @Description(shortDefinition = "The order in which to sort the results by")
043        private SortSpec mySort;
044
045        @Description(
046                        shortDefinition =
047                                        "Filter the resources to return only resources matching the given _content filter (note that this filter is applied only to results which link to the given patient, not to the patient itself or to supporting resources linked to by the matched resources)")
048        private StringAndListParam myContent;
049
050        @Description(
051                        shortDefinition =
052                                        "Filter the resources to return only resources matching the given _text filter (note that this filter is applied only to results which link to the given patient, not to the patient itself or to supporting resources linked to by the matched resources)")
053        private StringAndListParam myNarrative;
054
055        @Description(
056                        shortDefinition =
057                                        "Filter the resources to return only resources matching the given _filter filter (note that this filter is applied only to results which link to the given patient, not to the patient itself or to supporting resources linked to by the matched resources)")
058        private StringAndListParam myFilter;
059
060        @Description(
061                        shortDefinition =
062                                        "Filter the resources to return only resources matching the given _type filter (note that this filter is applied only to results which link to the given patient, not to the patient itself or to supporting resources linked to by the matched resources)")
063        private StringAndListParam myTypes;
064
065        @Description(
066                        shortDefinition = "If set to true, trigger an MDM expansion of identifiers corresponding to the resources.")
067        private boolean myMdmExpand = false;
068
069        public IPrimitiveType<Integer> getCount() {
070                return myCount;
071        }
072
073        public IPrimitiveType<Integer> getOffset() {
074                return myOffset;
075        }
076
077        public DateRangeParam getLastUpdated() {
078                return myLastUpdated;
079        }
080
081        public SortSpec getSort() {
082                return mySort;
083        }
084
085        public StringAndListParam getContent() {
086                return myContent;
087        }
088
089        public StringAndListParam getNarrative() {
090                return myNarrative;
091        }
092
093        public StringAndListParam getFilter() {
094                return myFilter;
095        }
096
097        public StringAndListParam getTypes() {
098                return myTypes;
099        }
100
101        public boolean getMdmExpand() {
102                return myMdmExpand;
103        }
104
105        public void setCount(IPrimitiveType<Integer> theCount) {
106                this.myCount = theCount;
107        }
108
109        public void setOffset(IPrimitiveType<Integer> theOffset) {
110                this.myOffset = theOffset;
111        }
112
113        public void setLastUpdated(DateRangeParam theLastUpdated) {
114                this.myLastUpdated = theLastUpdated;
115        }
116
117        public void setSort(SortSpec theSort) {
118                this.mySort = theSort;
119        }
120
121        public void setContent(StringAndListParam theContent) {
122                this.myContent = theContent;
123        }
124
125        public void setNarrative(StringAndListParam theNarrative) {
126                this.myNarrative = theNarrative;
127        }
128
129        public void setFilter(StringAndListParam theFilter) {
130                this.myFilter = theFilter;
131        }
132
133        public void setTypes(StringAndListParam theTypes) {
134                this.myTypes = theTypes;
135        }
136
137        public void setMdmExpand(Boolean myMdmExpand) {
138                this.myMdmExpand = myMdmExpand;
139        }
140}