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.client.api;
021
022import ca.uhn.fhir.model.primitive.IdDt;
023import ca.uhn.fhir.model.primitive.UriDt;
024import ca.uhn.fhir.rest.api.MethodOutcome;
025import ca.uhn.fhir.rest.client.exceptions.FhirClientConnectionException;
026import ca.uhn.fhir.rest.client.exceptions.FhirClientInappropriateForServerException;
027import ca.uhn.fhir.rest.gclient.ICreate;
028import ca.uhn.fhir.rest.gclient.IDelete;
029import ca.uhn.fhir.rest.gclient.IFetchConformanceUntyped;
030import ca.uhn.fhir.rest.gclient.IGetPage;
031import ca.uhn.fhir.rest.gclient.IHistory;
032import ca.uhn.fhir.rest.gclient.IMeta;
033import ca.uhn.fhir.rest.gclient.IOperation;
034import ca.uhn.fhir.rest.gclient.IPatch;
035import ca.uhn.fhir.rest.gclient.IRead;
036import ca.uhn.fhir.rest.gclient.ITransaction;
037import ca.uhn.fhir.rest.gclient.IUntypedQuery;
038import ca.uhn.fhir.rest.gclient.IUpdate;
039import ca.uhn.fhir.rest.gclient.IValidate;
040import org.hl7.fhir.instance.model.api.IBaseBundle;
041import org.hl7.fhir.instance.model.api.IBaseResource;
042
043public interface IGenericClient extends IRestfulClient {
044
045        /**
046         * Fetch the capability statement for the server
047         */
048        IFetchConformanceUntyped capabilities();
049
050        /**
051         * Fluent method for the "create" operation, which creates a new resource instance on the server
052         */
053        ICreate create();
054
055        /**
056         * Fluent method for the "delete" operation, which performs a logical delete on a server resource
057         */
058        IDelete delete();
059
060        /**
061         * Retrieves the server's conformance statement
062         *
063         * @deprecated As of HAPI 3.0.0 this method has been deprecated, as the operation is now called "capabilities". Use {@link #capabilities()} instead
064         */
065        IFetchConformanceUntyped fetchConformance();
066
067        /**
068         * Force the client to fetch the server's conformance statement and validate that it is appropriate for this client.
069         *
070         * @throws FhirClientConnectionException
071         *            if the conformance statement cannot be read, or if the client
072         * @throws FhirClientInappropriateForServerException
073         *            If the conformance statement indicates that the server is inappropriate for this client (e.g. it implements the wrong version of FHIR)
074         */
075        void forceConformanceCheck() throws FhirClientConnectionException;
076
077        /**
078         * Implementation of the "history" method
079         */
080        IHistory history();
081
082        /**
083         * Loads the previous/next bundle of resources from a paged set, using the link specified in the "link type=next" tag within the atom bundle.
084         */
085        IGetPage loadPage();
086
087        /**
088         * Fluent method for the "meta" operations, which can be used to get, add and remove tags and other
089         * Meta elements from a resource or across the server.
090         *
091         * @since 1.1
092         */
093        IMeta meta();
094
095        /**
096         * Implementation of the FHIR "extended operations" action
097         */
098        IOperation operation();
099
100        /**
101         * Fluent method for the "patch" operation, which performs a logical patch on a server resource
102         */
103        IPatch patch();
104
105        /**
106         * Fluent method for "read" and "vread" methods.
107         */
108        IRead read();
109
110        /**
111         * Implementation of the "instance read" method.
112         *
113         * @param theType
114         *           The type of resource to load
115         * @param theId
116         *           The ID to load
117         * @return The resource
118         *
119         * @deprecated Use {@link #read() read() fluent method} instead (deprecated in HAPI FHIR 3.0.0)
120         */
121        @Deprecated
122        <T extends IBaseResource> T read(Class<T> theType, String theId);
123
124        /**
125         * Perform the "read" operation (retrieve the latest version of a resource instance by ID) using an absolute URL.
126         *
127         * @param theType
128         *           The resource type that is being retrieved
129         * @param theUrl
130         *           The absolute URL, e.g. "http://example.com/fhir/Patient/123"
131         * @return The returned resource from the server
132         * @deprecated Use {@link #read() read() fluent method} instead (deprecated in HAPI FHIR 3.0.0)
133         */
134        @Deprecated
135        <T extends IBaseResource> T read(Class<T> theType, UriDt theUrl);
136
137        /**
138         * Perform the "read" operation (retrieve the latest version of a resource instance by ID) using an absolute URL.
139         *
140         * @param theUrl
141         *           The absolute URL, e.g. "http://example.com/fhir/Patient/123"
142         * @return The returned resource from the server
143         * @deprecated Use {@link #read() read() fluent method} instead (deprecated in HAPI FHIR 3.0.0)
144         */
145        @Deprecated
146        IBaseResource read(UriDt theUrl);
147
148        /**
149         * Register a new interceptor for this client. An interceptor can be used to add additional logging, or add security headers, or pre-process responses, etc.
150         */
151        @Override
152        void registerInterceptor(Object theInterceptor);
153
154        /**
155         * Search for resources matching a given set of criteria. Searching is a very powerful
156         * feature in FHIR with many features for specifying exactly what should be seaerched for
157         * and how it should be returned. See the <a href="http://www.hl7.org/fhir/search.html">specification on search</a>
158         * for more information.
159         */
160        <T extends IBaseBundle> IUntypedQuery<T> search();
161
162        /**
163         * If set to <code>true</code>, the client will log all requests and all responses. This is probably not a good production setting since it will result in a lot of extra logging, but it can be
164         * useful for troubleshooting.
165         *
166         * @param theLogRequestAndResponse
167         *           Should requests and responses be logged
168         * @deprecated Use LoggingInterceptor as a client interceptor registered to your
169         *             client instead, as this provides much more fine-grained control over what is logged. This
170         *             method will be removed at some point (deprecated in HAPI 1.6 - 2016-06-16)
171         */
172        @Deprecated
173        void setLogRequestAndResponse(boolean theLogRequestAndResponse);
174
175        /**
176         * Send a transaction (collection of resources) to the server to be executed as a single unit
177         */
178        ITransaction transaction();
179
180        /**
181         * Remove an intercaptor that was previously registered using {@link IRestfulClient#registerInterceptor(Object)}
182         */
183        @Override
184        void unregisterInterceptor(Object theInterceptor);
185
186        /**
187         * Fluent method for the "update" operation, which updates a resource instance on the server
188         */
189        IUpdate update();
190
191        /**
192         * Implementation of the "instance update" method.
193         *
194         * @param theId
195         *           The ID to update
196         * @param theResource
197         *           The new resource body
198         * @return An outcome containing the results and possibly the new version ID
199         * @deprecated Use {@link #update() update() fluent method} instead (deprecated in HAPI FHIR 3.0.0)
200         */
201        @Deprecated
202        MethodOutcome update(IdDt theId, IBaseResource theResource);
203
204        /**
205         * Implementation of the "instance update" method.
206         *
207         * @param theId
208         *           The ID to update
209         * @param theResource
210         *           The new resource body
211         * @return An outcome containing the results and possibly the new version ID
212         * @deprecated Use {@link #update() update() fluent method} instead (deprecated in HAPI FHIR 3.0.0)
213         */
214        @Deprecated
215        MethodOutcome update(String theId, IBaseResource theResource);
216
217        /**
218         * Validate a resource
219         */
220        IValidate validate();
221
222        /**
223         * Implementation of the "type validate" method.
224         *
225         * @param theResource
226         *           The resource to validate
227         * @return An outcome containing any validation issues
228         * @deprecated Use {@link #validate() validate() fluent method} instead (deprecated in HAPI FHIR 3.0.0)
229         */
230        @Deprecated
231        MethodOutcome validate(IBaseResource theResource);
232
233        /**
234         * Implementation of the "instance vread" method. Note that this method expects <code>theId</code> to contain a resource ID as well as a version ID, and will fail if it does not.
235         * <p>
236         * Note that if an absolute resource ID is passed in (i.e. a URL containing a protocol and host as well as the resource type and ID) the server base for the client will be ignored, and the URL
237         * passed in will be queried.
238         * </p>
239         *
240         * @param theType
241         *           The type of resource to load
242         * @param theId
243         *           The ID to load, including the resource ID and the resource version ID. Valid values include "Patient/123/_history/222", or "http://example.com/fhir/Patient/123/_history/222"
244         * @return The resource
245         * @deprecated Use {@link #read() read() fluent method} instead (deprecated in HAPI FHIR 3.0.0)
246         */
247        @Deprecated
248        <T extends IBaseResource> T vread(Class<T> theType, IdDt theId);
249
250        /**
251         * Implementation of the "instance vread" method.
252         *
253         * @param theType
254         *           The type of resource to load
255         * @param theId
256         *           The ID to load
257         * @param theVersionId
258         *           The version ID
259         * @return The resource
260         * @deprecated Use {@link #read() read() fluent method} instead (deprecated in HAPI FHIR 3.0.0)
261         */
262        @Deprecated
263        <T extends IBaseResource> T vread(Class<T> theType, String theId, String theVersionId);
264}