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.rest.api.CacheControlDirective; 023import ca.uhn.fhir.rest.api.EncodingEnum; 024import ca.uhn.fhir.rest.api.RequestFormatParamStyleEnum; 025import ca.uhn.fhir.rest.api.SummaryEnum; 026import org.hl7.fhir.instance.model.api.IBaseResource; 027 028import java.util.List; 029 030public interface IClientExecutable<T extends IClientExecutable<?, Y>, Y> { 031 032 /** 033 * If set to true, the client will log the request and response to the SLF4J logger. This can be useful for 034 * debugging, but is generally not desirable in a production situation. 035 * 036 * @deprecated Use the client logging interceptor to log requests and responses instead. See <a href="https://hapifhir.io/hapi-fhir/docs/interceptors/built_in_client_interceptors.html">here</a> for more information. 037 */ 038 @Deprecated 039 T andLogRequestAndResponse(boolean theLogRequestAndResponse); 040 041 /** 042 * Sets the <code>Cache-Control</code> header value, which advises the server (or any cache in front of it) 043 * how to behave in terms of cached requests 044 */ 045 T cacheControl(CacheControlDirective theCacheControlDirective); 046 047 /** 048 * Request that the server return subsetted resources, containing only the elements specified in the given parameters. 049 * For example: <code>subsetElements("name", "identifier")</code> requests that the server only return 050 * the "name" and "identifier" fields in the returned resource, and omit any others. 051 */ 052 T elementsSubset(String... theElements); 053 054 /** 055 * Request that the server respond with JSON via the Accept header and possibly also the 056 * <code>_format</code> parameter if {@link ca.uhn.fhir.rest.client.api.IRestfulClient#setFormatParamStyle(RequestFormatParamStyleEnum) configured to do so}. 057 * <p> 058 * This method will have no effect if {@link #accept(String) a custom Accept header} is specified. 059 * </p> 060 * 061 * @see #accept(String) 062 */ 063 T encoded(EncodingEnum theEncoding); 064 065 /** 066 * Request that the server respond with JSON via the Accept header and possibly also the 067 * <code>_format</code> parameter if {@link ca.uhn.fhir.rest.client.api.IRestfulClient#setFormatParamStyle(RequestFormatParamStyleEnum) configured to do so}. 068 * <p> 069 * This method will have no effect if {@link #accept(String) a custom Accept header} is specified. 070 * </p> 071 * 072 * @see #accept(String) 073 * @see #encoded(EncodingEnum) 074 */ 075 T encodedJson(); 076 077 /** 078 * Request that the server respond with JSON via the Accept header and possibly also the 079 * <code>_format</code> parameter if {@link ca.uhn.fhir.rest.client.api.IRestfulClient#setFormatParamStyle(RequestFormatParamStyleEnum) configured to do so}. 080 * <p> 081 * This method will have no effect if {@link #accept(String) a custom Accept header} is specified. 082 * </p> 083 * 084 * @see #accept(String) 085 * @see #encoded(EncodingEnum) 086 */ 087 T encodedXml(); 088 089 /** 090 * Set a HTTP header not explicitly defined in FHIR but commonly used in real-world scenarios. One 091 * important example is to set the Authorization header (e.g. Basic Auth or OAuth2-based Bearer auth), 092 * which tends to be cumbersome using {@link ca.uhn.fhir.rest.client.api.IClientInterceptor IClientInterceptors}, 093 * particularly when REST clients shall be reused and are thus supposed to remain stateless. 094 * <p>It is the responsibility of the caller to care for proper encoding of the header value, e.g. 095 * using Base64.</p> 096 * <p>This is a short-cut alternative to using a corresponding client interceptor</p> 097 * 098 * @param theHeaderName header name 099 * @param theHeaderValue header value 100 * @return 101 */ 102 T withAdditionalHeader(String theHeaderName, String theHeaderValue); 103 104 /** 105 * Actually execute the client operation 106 */ 107 Y execute(); 108 109 /** 110 * Explicitly specify a custom structure type to attempt to use when parsing the response. This 111 * is useful for invocations where the response is a Bundle/Parameters containing nested resources, 112 * and you want to use specific custom structures for those nested resources. 113 * <p> 114 * See <a href="https://jamesagnew.github.io/hapi-fhir/doc_extensions.html">Profiles and Extensions</a> for more information on using custom structures 115 * </p> 116 */ 117 T preferResponseType(Class<? extends IBaseResource> theType); 118 119 /** 120 * Explicitly specify a list of custom structure types to attempt to use (in order from most to 121 * least preferred) when parsing the response. This 122 * is useful for invocations where the response is a Bundle/Parameters containing nested resources, 123 * and you want to use specific custom structures for those nested resources. 124 * <p> 125 * See <a href="https://jamesagnew.github.io/hapi-fhir/doc_extensions.html">Profiles and Extensions</a> for more information on using custom structures 126 * </p> 127 */ 128 T preferResponseTypes(List<Class<? extends IBaseResource>> theTypes); 129 130 /** 131 * Request pretty-printed response via the <code>_pretty</code> parameter 132 */ 133 T prettyPrint(); 134 135 /** 136 * Request that the server modify the response using the <code>_summary</code> param 137 */ 138 T summaryMode(SummaryEnum theSummary); 139 140 /** 141 * Specifies a custom <code>Accept</code> header that should be supplied with the 142 * request. 143 * <p> 144 * Note that this method overrides any encoding preferences specified with 145 * {@link #encodedJson()} or {@link #encodedXml()}. It is generally easier to 146 * just use those methods if you simply want to request a specific FHIR encoding. 147 * </p> 148 * 149 * @param theHeaderValue The header value, e.g. "application/fhir+json". Constants such 150 * as {@link ca.uhn.fhir.rest.api.Constants#CT_FHIR_XML_NEW} and 151 * {@link ca.uhn.fhir.rest.api.Constants#CT_FHIR_JSON_NEW} may 152 * be useful. If set to <code>null</code> or an empty string, the 153 * default Accept header will be used. 154 * @see #encoded(EncodingEnum) 155 * @see #encodedJson() 156 * @see #encodedXml() 157 */ 158 T accept(String theHeaderValue); 159}