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.gclient; 021 022import ca.uhn.fhir.model.api.Include; 023import ca.uhn.fhir.rest.api.SearchStyleEnum; 024import ca.uhn.fhir.rest.api.SearchTotalModeEnum; 025import ca.uhn.fhir.rest.api.SortSpec; 026import ca.uhn.fhir.rest.param.DateRangeParam; 027import org.hl7.fhir.instance.model.api.IBaseBundle; 028 029import java.util.Collection; 030 031public interface IQuery<Y> extends IBaseQuery<IQuery<Y>>, IClientExecutable<IQuery<Y>, Y> { 032 033 /** 034 * {@inheritDoc} 035 */ 036 // This is here as an overridden method to allow mocking clients with Mockito to work 037 @Override 038 IQuery<Y> and(ICriterion<?> theCriterion); 039 040 /** 041 * Specifies the <code>_count</code> parameter, which indicates to the server how many resources should be returned 042 * on a single page. 043 * 044 * @since 1.4 045 */ 046 IQuery<Y> count(int theCount); 047 048 /** 049 * Specifies the <code>_offset</code> parameter, which indicates to the server the offset of the query. Use 050 * with {@link #count(int)}. 051 * 052 * This parameter is not part of the FHIR standard, all servers might not implement it. 053 * 054 * @since 5.2 055 */ 056 IQuery<Y> offset(int theOffset); 057 058 /** 059 * Add an "_include" specification or an "_include:recurse" specification. If you are using 060 * a constant from one of the built-in structures you can select whether you want recursive 061 * behaviour by using the following syntax: 062 * <ul> 063 * <li><b>Recurse:</b> <code>.include(Patient.INCLUDE_ORGANIZATION.asRecursive())</code> 064 * <li><b>No Recurse:</b> <code>.include(Patient.INCLUDE_ORGANIZATION.asNonRecursive())</code> 065 * </ul> 066 */ 067 IQuery<Y> include(Include theInclude); 068 069 /** 070 * Add a "_lastUpdated" specification 071 * 072 * @since HAPI FHIR 1.1 - Note that option was added to FHIR itself in DSTU2 073 */ 074 IQuery<Y> lastUpdated(DateRangeParam theLastUpdated); 075 076 /** 077 * Specifies the <code>_count</code> parameter, which indicates to the server how many resources should be returned 078 * on a single page. 079 * 080 * @deprecated This parameter is badly named, since FHIR calls this parameter "_count" and not "_limit". Use {@link #count(int)} instead (it also sets the _count parameter) 081 * @see #count(int) 082 */ 083 @Deprecated 084 IQuery<Y> limitTo(int theLimitTo); 085 086 /** 087 * Request that the client return the specified bundle type, e.g. <code>org.hl7.fhir.dstu2.model.Bundle.class</code> 088 * or <code>ca.uhn.fhir.model.dstu2.resource.Bundle.class</code> 089 */ 090 <B extends IBaseBundle> IQuery<B> returnBundle(Class<B> theClass); 091 092 /** 093 * Request that the server modify the response using the <code>_total</code> param 094 * 095 * THIS IS AN EXPERIMENTAL FEATURE - Use with caution, as it may be 096 * removed or modified in a future version. 097 */ 098 IQuery<Y> totalMode(SearchTotalModeEnum theTotalMode); 099 100 /** 101 * Add a "_revinclude" specification 102 * 103 * @since HAPI FHIR 1.0 - Note that option was added to FHIR itself in DSTU2 104 */ 105 IQuery<Y> revInclude(Include theIncludeTarget); 106 107 /** 108 * Adds a sort criteria 109 * 110 * @see #sort(SortSpec) for an alternate way of speciyfing sorts 111 */ 112 ISort<Y> sort(); 113 114 /** 115 * Adds a sort using a {@link SortSpec} object 116 * 117 * @see #sort() for an alternate way of speciyfing sorts 118 */ 119 IQuery<Y> sort(SortSpec theSortSpec); 120 121 /** 122 * Forces the query to perform the search using the given method (allowable methods are described in the 123 * <a href="http://www.hl7.org/fhir/search.html">FHIR Search Specification</a>) 124 * <p> 125 * This can be used to force the use of an HTTP POST instead of an HTTP GET 126 * </p> 127 * 128 * @see SearchStyleEnum 129 * @since 0.6 130 */ 131 IQuery<Y> usingStyle(SearchStyleEnum theStyle); 132 133 /** 134 * {@inheritDoc} 135 */ 136 // This is here as an overridden method to allow mocking clients with Mockito to work 137 @Override 138 IQuery<Y> where(ICriterion<?> theCriterion); 139 140 /** 141 * Matches any of the profiles given as argument. This would result in an OR search for resources matching one or more profiles. 142 * To do an AND search, make multiple calls to {@link #withProfile(String)}. 143 * 144 * @param theProfileUris The URIs of a given profile to search for resources which match. 145 */ 146 IQuery<Y> withAnyProfile(Collection<String> theProfileUris); 147 148 IQuery<Y> withIdAndCompartment(String theResourceId, String theCompartmentName); 149 150 /** 151 * Match only resources where the resource has the given profile declaration. This parameter corresponds to 152 * the <code>_profile</code> URL parameter. 153 * 154 * @param theProfileUri The URI of a given profile to search for resources which match 155 */ 156 IQuery<Y> withProfile(String theProfileUri); 157 158 /** 159 * Match only resources where the resource has the given security tag. This parameter corresponds to 160 * the <code>_security</code> URL parameter. 161 * 162 * @param theSystem The tag code system, or <code>null</code> to match any code system (this may not be supported on all servers) 163 * @param theCode The tag code. Must not be <code>null</code> or empty. 164 */ 165 IQuery<Y> withSecurity(String theSystem, String theCode); 166 167 /** 168 * Match only resources where the resource has the given tag. This parameter corresponds to 169 * the <code>_tag</code> URL parameter. 170 * 171 * @param theSystem The tag code system, or <code>null</code> to match any code system (this may not be supported on all servers) 172 * @param theCode The tag code. Must not be <code>null</code> or empty. 173 */ 174 IQuery<Y> withTag(String theSystem, String theCode); 175 176 // Y execute(); 177 178}