Class ResteasyClientImpl
- java.lang.Object
-
- org.jboss.resteasy.client.jaxrs.internal.ResteasyClientImpl
-
- All Implemented Interfaces:
Client,Configurable<Client>,AutoCloseable,ResteasyClient
public class ResteasyClientImpl extends Object implements ResteasyClient
- Version:
- $Revision: 1 $
- Author:
- Bill Burke
-
-
Field Summary
Fields Modifier and Type Field Description protected booleancleanupExecutorprotected booleanclosedprotected ClientConfigurationconfigurationprotected ClientHttpEnginehttpEngine
-
Constructor Summary
Constructors Modifier Constructor Description protectedResteasyClientImpl(ClientHttpEngine httpEngine, ExecutorService asyncInvocationExecutor, boolean cleanupExecutor, ScheduledExecutorService scheduledExecutorService, ClientConfiguration configuration)protectedResteasyClientImpl(ClientHttpEngine httpEngine, ExecutorService asyncInvocationExecutor, boolean cleanupExecutor, ClientConfiguration configuration)protectedResteasyClientImpl(ClientHttpEngine httpEngine, ExecutorService asyncInvocationExecutor, boolean cleanupExecutor, ContextualScheduledExecutorService scheduledExecutorService, ClientConfiguration configuration)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidabortIfClosed()ExecutorServiceasyncInvocationExecutor()voidclose()Close client instance and all it's associated resources.protected ResteasyWebTargetcreateClientWebTarget(ResteasyClientImpl client, UriBuilder uriBuilder, ClientConfiguration configuration)protected ResteasyWebTargetcreateClientWebTarget(ResteasyClientImpl client, String uri, ClientConfiguration configuration)protected ResteasyWebTargetcreateClientWebTarget(ResteasyClientImpl client, URI uri, ClientConfiguration configuration)ConfigurationgetConfiguration()Get a live view of an internal configuration state of this configurable instance.HostnameVerifiergetHostnameVerifier()Get the hostname verifier configured in the client ornullin case no hostname verifier has been configured.ScheduledExecutorServicegetScheduledExecutor()SSLContextgetSslContext()Get the SSL context configured to be used with the current client run-time.ClientHttpEnginehttpEngine()Invocation.Builderinvocation(Link link)Build an invocation builder from a link.booleanisClosed()ResteasyClientImplproperty(String name, Object value)Set the new configuration property, if already set, the existing value of the property will be updated.ResteasyClientImplregister(Class<?> componentClass)Register a class of a custom JAX-RS component (such as an extension provider or afeaturemeta-provider) to be instantiated and used in the scope of this configurable context.ResteasyClientImplregister(Class<?> componentClass, int priority)Register a class of a custom JAX-RS component (such as an extension provider or afeaturemeta-provider) to be instantiated and used in the scope of this configurable context.ResteasyClientImplregister(Class<?> componentClass, Class<?>... contracts)Register a class of a custom JAX-RS component (such as an extension provider or afeaturemeta-provider) to be instantiated and used in the scope of this configurable context.ResteasyClientImplregister(Class<?> componentClass, Map<Class<?>,Integer> contracts)Register a class of a custom JAX-RS component (such as an extension provider or afeaturemeta-provider) to be instantiated and used in the scope of this configurable context.ResteasyClientImplregister(Object component)Register an instance of a custom JAX-RS component (such as an extension provider or afeaturemeta-provider) to be instantiated and used in the scope of this configurable context.ResteasyClientImplregister(Object component, int priority)Register an instance of a custom JAX-RS component (such as an extension provider or afeaturemeta-provider) to be instantiated and used in the scope of this configurable context.ResteasyClientImplregister(Object component, Class<?>... contracts)Register an instance of a custom JAX-RS component (such as an extension provider or afeaturemeta-provider) to be instantiated and used in the scope of this configurable context.ResteasyClientImplregister(Object component, Map<Class<?>,Integer> contracts)Register an instance of a custom JAX-RS component (such as an extension provider or afeaturemeta-provider) to be instantiated and used in the scope of this configurable context.ResteasyWebTargettarget(Link link)Build a new web resource target.ResteasyWebTargettarget(UriBuilder uriBuilder)Build a new web resource target.ResteasyWebTargettarget(String uri)Build a new web resource target.ResteasyWebTargettarget(URI uri)Build a new web resource target.
-
-
-
Field Detail
-
httpEngine
protected final ClientHttpEngine httpEngine
-
configuration
protected ClientConfiguration configuration
-
closed
protected boolean closed
-
cleanupExecutor
protected boolean cleanupExecutor
-
-
Constructor Detail
-
ResteasyClientImpl
protected ResteasyClientImpl(ClientHttpEngine httpEngine, ExecutorService asyncInvocationExecutor, boolean cleanupExecutor, ScheduledExecutorService scheduledExecutorService, ClientConfiguration configuration)
-
ResteasyClientImpl
protected ResteasyClientImpl(ClientHttpEngine httpEngine, ExecutorService asyncInvocationExecutor, boolean cleanupExecutor, ContextualScheduledExecutorService scheduledExecutorService, ClientConfiguration configuration)
-
ResteasyClientImpl
protected ResteasyClientImpl(ClientHttpEngine httpEngine, ExecutorService asyncInvocationExecutor, boolean cleanupExecutor, ClientConfiguration configuration)
-
-
Method Detail
-
httpEngine
public ClientHttpEngine httpEngine()
- Specified by:
httpEnginein interfaceResteasyClient
-
asyncInvocationExecutor
public ExecutorService asyncInvocationExecutor()
- Specified by:
asyncInvocationExecutorin interfaceResteasyClient
-
getScheduledExecutor
public ScheduledExecutorService getScheduledExecutor()
- Specified by:
getScheduledExecutorin interfaceResteasyClient
-
abortIfClosed
public void abortIfClosed()
- Specified by:
abortIfClosedin interfaceResteasyClient
-
isClosed
public boolean isClosed()
- Specified by:
isClosedin interfaceResteasyClient
-
close
public void close()
Description copied from interface:ClientClose client instance and all it's associated resources. Subsequent calls have no effect and are ignored. Once the client is closed, invoking any other method on the client instance would result in an
Calling this method effectively invalidates allIllegalStateExceptionbeing thrown.resource targetsproduced by the client instance. Invoking any method on such targets once the client is closed would result in anIllegalStateExceptionbeing thrown.- Specified by:
closein interfaceAutoCloseable- Specified by:
closein interfaceClient
-
getConfiguration
public Configuration getConfiguration()
Description copied from interface:ConfigurableGet a live view of an internal configuration state of this configurable instance. Any changes made using methods of thisConfigurableinstance will be reflected in the returnedConfigurationinstance.The returned
Configurationinstance and the collection data it provides are not thread-safe wrt. modification made using methods on the parent configurable object.- Specified by:
getConfigurationin interfaceConfigurable<Client>- Returns:
- configuration live view of the internal configuration state.
-
getSslContext
public SSLContext getSslContext()
Description copied from interface:ClientGet the SSL context configured to be used with the current client run-time.- Specified by:
getSslContextin interfaceClient- Returns:
- SSL context configured to be used with the current client run-time.
-
getHostnameVerifier
public HostnameVerifier getHostnameVerifier()
Description copied from interface:ClientGet the hostname verifier configured in the client ornullin case no hostname verifier has been configured.- Specified by:
getHostnameVerifierin interfaceClient- Returns:
- client hostname verifier or
nullif not set.
-
property
public ResteasyClientImpl property(String name, Object value)
Description copied from interface:ConfigurableSet the new configuration property, if already set, the existing value of the property will be updated. Setting anullvalue into a property effectively removes the property from the property bag.- Specified by:
propertyin interfaceConfigurable<Client>- Parameters:
name- property name.value- (new) property value.nullvalue removes the property with the given name.- Returns:
- the updated configurable instance.
-
register
public ResteasyClientImpl register(Class<?> componentClass)
Description copied from interface:ConfigurableRegister a class of a custom JAX-RS component (such as an extension provider or afeaturemeta-provider) to be instantiated and used in the scope of this configurable context. Implementations SHOULD warn about and ignore registrations that do not conform to the requirements of supported JAX-RS component types in the given configurable context. Any subsequent registration attempts for a component type, for which a class or instance-based registration already exists in the system MUST be rejected by the JAX-RS implementation and a warning SHOULD be raised to inform the user about the rejected registration. The registered JAX-RS component class is registered as a contract provider of all the recognized JAX-RS or implementation-specific extension contracts including meta-provider contracts, such asFeatureorDynamicFeature.As opposed to component instances registered via
Configurable.register(Object)method, the lifecycle of components registered using this class-basedregister(...)method is fully managed by the JAX-RS implementation or any underlying IoC container supported by the implementation.- Specified by:
registerin interfaceConfigurable<Client>- Parameters:
componentClass- JAX-RS component class to be configured in the scope of this configurable context.- Returns:
- the updated configurable context.
-
register
public ResteasyClientImpl register(Class<?> componentClass, int priority)
Description copied from interface:ConfigurableRegister a class of a custom JAX-RS component (such as an extension provider or afeaturemeta-provider) to be instantiated and used in the scope of this configurable context.This registration method provides the same functionality as
Configurable.register(Class)except that any priority specified on the registered JAX-RS component class viajakarta.annotation.Priorityannotation is overridden with the suppliedpriorityvalue.Note that in case the priority is not applicable to a particular provider contract implemented by the class of the registered component, the supplied
priorityvalue will be ignored for that contract.- Specified by:
registerin interfaceConfigurable<Client>- Parameters:
componentClass- JAX-RS component class to be configured in the scope of this configurable context.priority- the overriding priority for the registered component and all the provider contracts the component implements.- Returns:
- the updated configurable context.
-
register
public ResteasyClientImpl register(Class<?> componentClass, Class<?>... contracts)
Description copied from interface:ConfigurableRegister a class of a custom JAX-RS component (such as an extension provider or afeaturemeta-provider) to be instantiated and used in the scope of this configurable context.This registration method provides the same functionality as
Configurable.register(Class)except the JAX-RS component class is only registered as a provider of the listed extension provider or meta-providercontracts. All explicitly enumerated contract types must represent a class or an interface implemented or extended by the registered component. Contracts that are notassignable fromthe registered component class MUST be ignored and implementations SHOULD raise a warning to inform users about the ignored contract(s).- Specified by:
registerin interfaceConfigurable<Client>- Parameters:
componentClass- JAX-RS component class to be configured in the scope of this configurable context.contracts- the specific extension provider or meta-provider contracts implemented by the component for which the component should be registered. Implementations MUST ignore attempts to register a component class for an empty ornullcollection of contracts via this method and SHOULD raise a warning about such event.- Returns:
- the updated configurable context.
-
register
public ResteasyClientImpl register(Class<?> componentClass, Map<Class<?>,Integer> contracts)
Description copied from interface:ConfigurableRegister a class of a custom JAX-RS component (such as an extension provider or afeaturemeta-provider) to be instantiated and used in the scope of this configurable context.This registration method provides same functionality as
Configurable.register(Class, Class[])except that any priority specified on the registered JAX-RS component class viajakarta.annotation.Priorityannotation is overridden for each extension provider contract type separately with an integer priority value specified as a value in the supplied map of [contract type, priority] pairs.Note that in case a priority is not applicable to a provider contract registered for the JAX-RS component, the supplied priority value is ignored for such contract.
- Specified by:
registerin interfaceConfigurable<Client>- Parameters:
componentClass- JAX-RS component class to be configured in the scope of this configurable context.contracts- map of the specific extension provider and meta-provider contracts and their associated priorities for which the JAX-RS component is registered. All contracts in the map must represent a class or an interface implemented or extended by the JAX-RS component. Contracts that are notassignable fromthe registered component class MUST be ignored and implementations SHOULD raise a warning to inform users about the ignored contract(s).- Returns:
- the updated configurable context.
-
register
public ResteasyClientImpl register(Object component)
Description copied from interface:ConfigurableRegister an instance of a custom JAX-RS component (such as an extension provider or afeaturemeta-provider) to be instantiated and used in the scope of this configurable context. Implementations SHOULD warn about and ignore registrations that do not conform to the requirements of supported JAX-RS component types in the given configurable context. Any subsequent registration attempts for a component type, for which a class or instance-based registration already exists in the system MUST be rejected by the JAX-RS implementation and a warning SHOULD be raised to inform the user about the rejected registration. The registered JAX-RS component is registered as a contract provider of all the recognized JAX-RS or implementation-specific extension contracts including meta-provider contracts, such asFeatureorDynamicFeature.As opposed to components registered via
Configurable.register(Class)method, the lifecycle of providers registered using this instance-basedregister(...)is not managed by JAX-RS runtime. The same registered component instance is used during the whole lifespan of the configurable context. Fields and properties of all registered JAX-RS component instances are injected with their declared dependencies (seeContext) by the JAX-RS runtime prior to use.- Specified by:
registerin interfaceConfigurable<Client>- Parameters:
component- JAX-RS component instance to be configured in the scope of this configurable context.- Returns:
- the updated configurable context.
-
register
public ResteasyClientImpl register(Object component, int priority)
Description copied from interface:ConfigurableRegister an instance of a custom JAX-RS component (such as an extension provider or afeaturemeta-provider) to be instantiated and used in the scope of this configurable context.This registration method provides the same functionality as
Configurable.register(Object)except that any priority specified on the registered JAX-RS component class viajakarta.annotation.Priorityannotation is overridden with the suppliedpriorityvalue.Note that in case the priority is not applicable to a particular provider contract implemented by the class of the registered component, the supplied
priorityvalue will be ignored for that contract.- Specified by:
registerin interfaceConfigurable<Client>- Parameters:
component- JAX-RS component instance to be configured in the scope of this configurable context.priority- the overriding priority for the registered component and all the provider contracts the component implements.- Returns:
- the updated configurable context.
-
register
public ResteasyClientImpl register(Object component, Class<?>... contracts)
Description copied from interface:ConfigurableRegister an instance of a custom JAX-RS component (such as an extension provider or afeaturemeta-provider) to be instantiated and used in the scope of this configurable context.This registration method provides the same functionality as
Configurable.register(Object)except the JAX-RS component class is only registered as a provider of the listed extension provider or meta-providercontracts. All explicitly enumerated contract types must represent a class or an interface implemented or extended by the registered component. Contracts that are notassignable fromthe registered component class MUST be ignored and implementations SHOULD raise a warning to inform users about the ignored contract(s).- Specified by:
registerin interfaceConfigurable<Client>- Parameters:
component- JAX-RS component instance to be configured in the scope of this configurable context.contracts- the specific extension provider or meta-provider contracts implemented by the component for which the component should be registered. Implementations MUST ignore attempts to register a component class for an empty ornullcollection of contracts via this method and SHOULD raise a warning about such event.- Returns:
- the updated configurable context.
-
register
public ResteasyClientImpl register(Object component, Map<Class<?>,Integer> contracts)
Description copied from interface:ConfigurableRegister an instance of a custom JAX-RS component (such as an extension provider or afeaturemeta-provider) to be instantiated and used in the scope of this configurable context.This registration method provides same functionality as
Configurable.register(Object, Class[])except that any priority specified on the registered JAX-RS component class viajakarta.annotation.Priorityannotation is overridden for each extension provider contract type separately with an integer priority value specified as a value in the supplied map of [contract type, priority] pairs.Note that in case a priority is not applicable to a provider contract registered for the JAX-RS component, the supplied priority value is ignored for such contract.
- Specified by:
registerin interfaceConfigurable<Client>- Parameters:
component- JAX-RS component instance to be configured in the scope of this configurable context.contracts- map of the specific extension provider and meta-provider contracts and their associated priorities for which the JAX-RS component is registered. All contracts in the map must represent a class or an interface implemented or extended by the JAX-RS component. Contracts that are notassignable fromthe registered component class MUST be ignored and implementations SHOULD raise a warning to inform users about the ignored contract(s).- Returns:
- the updated configurable context.
-
target
public ResteasyWebTarget target(String uri) throws IllegalArgumentException, NullPointerException
Description copied from interface:ClientBuild a new web resource target.- Specified by:
targetin interfaceClient- Specified by:
targetin interfaceResteasyClient- Parameters:
uri- web resource URI. May contain template parameters. Must not benull.- Returns:
- web resource target bound to the provided URI.
- Throws:
IllegalArgumentException- in case the supplied string is not a valid URI template.NullPointerException- in case the supplied argument isnull.
-
target
public ResteasyWebTarget target(URI uri) throws NullPointerException
Description copied from interface:ClientBuild a new web resource target.- Specified by:
targetin interfaceClient- Specified by:
targetin interfaceResteasyClient- Parameters:
uri- web resource URI. Must not benull.- Returns:
- web resource target bound to the provided URI.
- Throws:
NullPointerException- in case the supplied argument isnull.
-
target
public ResteasyWebTarget target(UriBuilder uriBuilder) throws NullPointerException
Description copied from interface:ClientBuild a new web resource target.- Specified by:
targetin interfaceClient- Specified by:
targetin interfaceResteasyClient- Parameters:
uriBuilder- web resource URI represented as URI builder. Must not benull.- Returns:
- web resource target bound to the provided URI.
- Throws:
NullPointerException- in case the supplied argument isnull.
-
target
public ResteasyWebTarget target(Link link) throws NullPointerException
Description copied from interface:ClientBuild a new web resource target.- Specified by:
targetin interfaceClient- Specified by:
targetin interfaceResteasyClient- Parameters:
link- link to a web resource. Must not benull.- Returns:
- web resource target bound to the linked web resource.
- Throws:
NullPointerException- in case the supplied argument isnull.
-
invocation
public Invocation.Builder invocation(Link link) throws NullPointerException, IllegalArgumentException
Description copied from interface:ClientBuild an invocation builder from a link. It uses the URI and the type of the link to initialize the invocation builder. The type is used as the initial value for the HTTP Accept header, if present.
- Specified by:
invocationin interfaceClient- Parameters:
link- link to build invocation from. Must not benull.- Returns:
- newly created invocation builder.
- Throws:
NullPointerException- in case link isnull.IllegalArgumentException
-
createClientWebTarget
protected ResteasyWebTarget createClientWebTarget(ResteasyClientImpl client, String uri, ClientConfiguration configuration)
-
createClientWebTarget
protected ResteasyWebTarget createClientWebTarget(ResteasyClientImpl client, URI uri, ClientConfiguration configuration)
-
createClientWebTarget
protected ResteasyWebTarget createClientWebTarget(ResteasyClientImpl client, UriBuilder uriBuilder, ClientConfiguration configuration)
-
-