ca.uhn.fhir.rest.client.api.IRestfulClientFactory Maven / Gradle / Ivy
/*
* #%L
* HAPI FHIR - Core Library
* %%
* Copyright (C) 2014 - 2024 Smile CDR, Inc.
* %%
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
* #L%
*/
package ca.uhn.fhir.rest.client.api;
import ca.uhn.fhir.context.ConfigurationException;
import ca.uhn.fhir.rest.api.RequestTypeEnum;
import java.util.List;
import java.util.Map;
public interface IRestfulClientFactory {
/**
* Default value for {@link #getConnectTimeout()}
*/
public static final int DEFAULT_CONNECT_TIMEOUT = 10000;
/**
* Default value for {@link #getConnectionRequestTimeout()}
*/
public static final int DEFAULT_CONNECTION_REQUEST_TIMEOUT = 10000;
/**
* Default value for {@link #getServerValidationModeEnum()}
*/
public static final ServerValidationModeEnum DEFAULT_SERVER_VALIDATION_MODE = ServerValidationModeEnum.ONCE;
/**
* Default value for {@link #getSocketTimeout()}
*/
public static final int DEFAULT_SOCKET_TIMEOUT = 10000;
/**
* Default value for {@link #getPoolMaxTotal() ()}
*/
public static final int DEFAULT_POOL_MAX = 20;
/**
* Default value for {@link #getPoolMaxPerRoute() }
*/
public static final int DEFAULT_POOL_MAX_PER_ROUTE = DEFAULT_POOL_MAX;
/**
* Gets the connection request timeout, in milliseconds. This is the amount of time that the HTTPClient connection
* pool may wait for an available connection before failing. This setting typically does not need to be adjusted.
*
* The default value for this setting is defined by {@link #DEFAULT_CONNECTION_REQUEST_TIMEOUT}
*
*/
int getConnectionRequestTimeout();
/**
* Gets the connect timeout, in milliseconds. This is the amount of time that the initial connection attempt network
* operation may block without failing.
*
* The default value for this setting is defined by {@link #DEFAULT_CONNECT_TIMEOUT}
*
*/
int getConnectTimeout();
/**
* Returns the HTTP client instance. This method will not return null.
* @param theUrl
* The complete FHIR url to which the http request will be sent
* @param theIfNoneExistParams
* The params for header "If-None-Exist" as a hashmap
* @param theIfNoneExistString
* The param for header "If-None-Exist" as a string
* @param theRequestType
* the type of HTTP request (GET, DELETE, ..)
* @param theHeaders
* the headers to be sent together with the http request
* @return the HTTP client instance
*/
IHttpClient getHttpClient(
StringBuilder theUrl,
Map> theIfNoneExistParams,
String theIfNoneExistString,
RequestTypeEnum theRequestType,
List theHeaders);
/**
* @deprecated Use {@link #getServerValidationMode()} instead (this method is a synonym for that method, but this method is poorly named and will be removed at some point)
*/
@Deprecated
ServerValidationModeEnum getServerValidationModeEnum();
/**
* Gets the server validation mode for any clients created from this factory. Server
* validation involves the client requesting the server's conformance statement
* to determine whether the server is appropriate for the given client.
*
* The default value for this setting is defined by {@link #DEFAULT_SERVER_VALIDATION_MODE}
*
*
* @since 1.0
*/
ServerValidationModeEnum getServerValidationMode();
/**
* Gets the socket timeout, in milliseconds. This is the SO_TIMEOUT time, which is the amount of time that a
* read/write network operation may block without failing.
*
* The default value for this setting is defined by {@link #DEFAULT_SOCKET_TIMEOUT}
*
*/
int getSocketTimeout();
/**
* Gets the maximum number of connections allowed in the pool.
*
* The default value for this setting is defined by {@link #DEFAULT_POOL_MAX}
*
*/
int getPoolMaxTotal();
/**
* Gets the maximum number of connections per route allowed in the pool.
*
* The default value for this setting is defined by {@link #DEFAULT_POOL_MAX_PER_ROUTE}
*
*/
int getPoolMaxPerRoute();
/**
* Instantiates a new client instance
*
* @param theClientType
* The client type, which is an interface type to be instantiated
* @param theServerBase
* The URL of the base for the restful FHIR server to connect to
* @return A newly created client
* @throws ConfigurationException
* If the interface type is not an interface
*/
T newClient(Class theClientType, String theServerBase);
/**
* Instantiates a new generic client instance
*
* @param theServerBase
* The URL of the base for the restful FHIR server to connect to
* @return A newly created client
*/
IGenericClient newGenericClient(String theServerBase);
/**
* Sets the connection request timeout, in milliseconds. This is the amount of time that the HTTPClient connection
* pool may wait for an available connection before failing. This setting typically does not need to be adjusted.
*
* The default value for this setting is defined by {@link #DEFAULT_CONNECTION_REQUEST_TIMEOUT}
*
*/
void setConnectionRequestTimeout(int theConnectionRequestTimeout);
/**
* Sets the connect timeout, in milliseconds. This is the amount of time that the initial connection attempt network
* operation may block without failing.
*
* The default value for this setting is defined by {@link #DEFAULT_CONNECT_TIMEOUT}
*
*/
void setConnectTimeout(int theConnectTimeout);
/**
* Sets the Apache HTTP client instance to be used by any new restful clients created by this factory. If set to
* null
, a new HTTP client with default settings will be created.
*
* @param theHttpClient
* An HTTP client instance to use, or null
*/
void setHttpClient(T theHttpClient);
/**
* Sets the HTTP proxy to use for outgoing connections
*
* @param theHost
* The host (or null to disable proxying, as is the default)
* @param thePort
* The port (or null to disable proxying, as is the default)
*/
void setProxy(String theHost, Integer thePort);
/**
* Sets the credentials to use to authenticate with the HTTP proxy,
* if one is defined. Set to null to use no authentication with the proxy.
* @param theUsername The username
* @param thePassword The password
*/
void setProxyCredentials(String theUsername, String thePassword);
/**
* @deprecated Use {@link #setServerValidationMode(ServerValidationModeEnum)} instead. This method was incorrectly named.
*/
@Deprecated
void setServerValidationModeEnum(ServerValidationModeEnum theServerValidationMode);
/**
* Sets the server validation mode for any clients created from this factory. Server
* validation involves the client requesting the server's conformance statement
* to determine whether the server is appropriate for the given client.
*
* This check is primarily to validate that the server supports an appropriate
* version of FHIR
*
*
* The default value for this setting is defined by {@link #DEFAULT_SERVER_VALIDATION_MODE}
*
*
* @since 1.0
*/
void setServerValidationMode(ServerValidationModeEnum theServerValidationMode);
/**
* Sets the socket timeout, in milliseconds. This is the SO_TIMEOUT time, which is the amount of time that a
* read/write network operation may block without failing.
*
* The default value for this setting is defined by {@link #DEFAULT_SOCKET_TIMEOUT}
*
*/
void setSocketTimeout(int theSocketTimeout);
/**
* Sets the maximum number of connections allowed in the pool.
*
* The default value for this setting is defined by {@link #DEFAULT_POOL_MAX}
*
*/
void setPoolMaxTotal(int thePoolMaxTotal);
/**
* Sets the maximum number of connections per route allowed in the pool.
*
* The default value for this setting is defined by {@link #DEFAULT_POOL_MAX_PER_ROUTE}
*
*/
void setPoolMaxPerRoute(int thePoolMaxPerRoute);
void validateServerBase(String theServerBase, IHttpClient theHttpClient, IRestfulClient theClient);
/**
* This method is internal to HAPI - It may change in future versions, use with caution.
*/
void validateServerBaseIfConfiguredToDoSo(
String theServerBase, IHttpClient theHttpClient, IRestfulClient theClient);
}