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.context.FhirContext;
023import ca.uhn.fhir.interceptor.api.IInterceptorService;
024import ca.uhn.fhir.rest.api.EncodingEnum;
025import ca.uhn.fhir.rest.api.RequestFormatParamStyleEnum;
026import ca.uhn.fhir.rest.api.SummaryEnum;
027import jakarta.annotation.Nonnull;
028import org.hl7.fhir.instance.model.api.IBaseResource;
029
030public interface IRestfulClient {
031
032        /**
033         * Sets the interfceptor service used by this client
034         *
035         * @since 3.8.0
036         */
037        IInterceptorService getInterceptorService();
038
039        /**
040         * Sets the interfceptor service used by this client
041         *
042         * @since 3.8.0
043         */
044        void setInterceptorService(@Nonnull IInterceptorService theInterceptorService);
045
046        /**
047         * Retrieve the contents at the given URL and parse them as a resource. This
048         * method could be used as a low level implementation of a read/vread/search
049         * operation.
050         *
051         * @param theResourceType The resource type to parse
052         * @param theUrl          The URL to load
053         * @return The parsed resource
054         */
055        <T extends IBaseResource> T fetchResourceFromUrl(Class<T> theResourceType, String theUrl);
056
057        /**
058         * Returns the encoding that will be used on requests. Default is <code>null</code>, which means the client will not
059         * explicitly request an encoding. (This is standard behaviour according to the FHIR specification)
060         */
061        EncodingEnum getEncoding();
062
063        /**
064         * Specifies that the client should use the given encoding to do its
065         * queries. This means that the client will append the "_format" param
066         * to GET methods (read/search/etc), and will add an appropriate header for
067         * write methods.
068         *
069         * @param theEncoding The encoding to use in the request, or <code>null</code> not specify
070         *                    an encoding (which generally implies the use of XML). The default is <code>null</code>.
071         */
072        void setEncoding(EncodingEnum theEncoding);
073
074        /**
075         * Returns the FHIR context associated with this client
076         */
077        FhirContext getFhirContext();
078
079        /**
080         * Do not call this method in client code. It is a part of the internal HAPI API and
081         * is subject to change!
082         */
083        IHttpClient getHttpClient();
084
085        /**
086         * Base URL for the server, with no trailing "/"
087         */
088        String getServerBase();
089
090        /**
091         * Register a new interceptor for this client. An interceptor can be used to add additional
092         * logging, or add security headers, or pre-process responses, etc.
093         * <p>
094         * This is a convenience method for performing the following call:
095         * <code>getInterceptorService().registerInterceptor(theInterceptor)</code>
096         * </p>
097         */
098        void registerInterceptor(Object theInterceptor);
099
100        /**
101         * Specifies that the client should request that the server respond with "pretty printing"
102         * enabled. Note that this is a non-standard parameter, not all servers will
103         * support it.
104         *
105         * @param thePrettyPrint The pretty print flag to use in the request (default is <code>false</code>)
106         */
107        void setPrettyPrint(Boolean thePrettyPrint);
108
109        /**
110         * If not set to <code>null</code>, specifies a value for the <code>_summary</code> parameter
111         * to be applied globally on this client.
112         */
113        void setSummary(SummaryEnum theSummary);
114
115        /**
116         * Remove an interceptor that was previously registered using {@link IRestfulClient#registerInterceptor(Object)}.
117         * <p>
118         * This is a convenience method for performing the following call:
119         * <code>getInterceptorService().unregisterInterceptor(theInterceptor)</code>
120         * </p>
121         */
122        void unregisterInterceptor(Object theInterceptor);
123
124        /**
125         * Configures what style of _format parameter should be used in requests
126         */
127        void setFormatParamStyle(RequestFormatParamStyleEnum theRequestFormatParamStyle);
128}