Interface HttpClientTransport
- All Superinterfaces:
ClientConnectionFactory, HttpClient.Aware
- All Known Implementing Classes:
AbstractConnectorHttpClientTransport, AbstractHttpClientTransport, HttpClientTransportDynamic, HttpClientTransportOverFCGI, HttpClientTransportOverHTTP, HttpClientTransportOverHTTP2, HttpClientTransportOverHTTP3
HttpClientTransport represents what transport implementations should provide
in order to plug-in a different transport for HttpClient.
While the HttpClient APIs define the HTTP semantic (request, response, headers, etc.)
how an HTTP exchange is carried over the network depends on implementations of this class.
The default implementation uses the HTTP protocol to carry over the network the HTTP exchange, but the HTTP exchange may also be carried using the FCGI protocol, the HTTP/2 protocol or, in future, other protocols.
-
Nested Class Summary
Nested classes/interfaces inherited from interface ClientConnectionFactory
ClientConnectionFactory.Decorator, ClientConnectionFactory.Info -
Field Summary
FieldsFields inherited from interface ClientConnectionFactory
CLIENT_CONTEXT_KEY -
Method Summary
Modifier and TypeMethodDescriptionvoidconnect(InetSocketAddress address, Map<String, Object> context) Deprecated.default voidconnect(SocketAddress address, Map<String, Object> context) Establishes a physical connection to the givenaddress.newDestination(Origin origin) Creates a new, transport-specific,HttpDestinationobject.Creates a new Origin with the given request.voidSet the factory for ConnectionPool instances.voidsetHttpClient(HttpClient client) Sets theHttpClientinstance on this transport.Methods inherited from interface ClientConnectionFactory
customize, newConnection
-
Field Details
-
HTTP_DESTINATION_CONTEXT_KEY
- See Also:
-
HTTP_CONNECTION_PROMISE_CONTEXT_KEY
- See Also:
-
-
Method Details
-
setHttpClient
Sets theHttpClientinstance on this transport.This is needed because of a chicken-egg problem: in order to create the
HttpClienta HttpClientTransport is needed, that therefore cannot have a reference yet to theHttpClient.- Specified by:
setHttpClientin interfaceHttpClient.Aware- Parameters:
client- theHttpClientthat uses this transport.
-
newOrigin
-
newDestination
Creates a new, transport-specific,HttpDestinationobject.HttpDestinationcontrols the destination-connection cardinality: protocols like HTTP have 1-N cardinality, while multiplexed protocols like HTTP/2 have a 1-1 cardinality.- Parameters:
origin- the destination origin- Returns:
- a new, transport-specific,
HttpDestinationobject
-
connect
Deprecated.useconnect(SocketAddress, Map)instead.Establishes a physical connection to the givenaddress.- Parameters:
address- the address to connect tocontext- the context information to establish the connection
-
connect
Establishes a physical connection to the givenaddress.- Parameters:
address- the address to connect tocontext- the context information to establish the connection
-
getConnectionPoolFactory
ConnectionPool.Factory getConnectionPoolFactory()- Returns:
- the factory for ConnectionPool instances
-
setConnectionPoolFactory
Set the factory for ConnectionPool instances.- Parameters:
factory- the factory for ConnectionPool instances
-
connect(SocketAddress, Map)instead.