Package io.micronaut.http.client
Class HttpVersionSelection
java.lang.Object
io.micronaut.http.client.HttpVersionSelection
This class collects information about HTTP client protocol version settings, such as the
 
HttpVersionSelection.PlaintextMode and the ALPN configuration.- Since:
- 4.0
- Author:
- Jonas Konrad
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic enumThe connection mode to use for plaintext (non-TLS) connections.
- 
Field SummaryFields
- 
Method SummaryModifier and TypeMethodDescriptionbooleanstatic @Nullable HttpVersionSelectionforClientAnnotation(AnnotationMetadata metadata) Infer the version selection for the givenClientannotation, if any version settings are set.static HttpVersionSelectionforClientConfiguration(HttpClientConfiguration clientConfiguration) Construct a version selection from the given client configuration.static @NonNull HttpVersionSelectionforLegacyVersion(@NonNull HttpVersion httpVersion) Get theHttpVersionSelectionthat matches Micronaut HTTP client 3.x behavior for the given version setting.static @NonNull HttpVersionSelectionGet theHttpVersionSelectionto be used for a WebSocket connection, which will enable ALPN but constrain the mode to HTTP 1.1.String[]inthashCode()booleanisAlpn()booleanbooleanisHttp3()
- 
Field Details- 
ALPN_HTTP_1ALPN protocol ID for HTTP/1.1.- See Also:
 
- 
ALPN_HTTP_2ALPN protocol ID for HTTP/2.- See Also:
 
- 
ALPN_HTTP_3ALPN protocol ID for HTTP/3. When this is selected, it must be the only ALPN ID, since we will connect via UDP.- See Also:
 
 
- 
- 
Method Details- 
forLegacyVersion@NonNull public static @NonNull HttpVersionSelection forLegacyVersion(@NonNull @NonNull HttpVersion httpVersion) Get theHttpVersionSelectionthat matches Micronaut HTTP client 3.x behavior for the given version setting.- Parameters:
- httpVersion- The HTTP version as configured for Micronaut HTTP client 3.x
- Returns:
- The version selection
 
- 
forWebsocketGet theHttpVersionSelectionto be used for a WebSocket connection, which will enable ALPN but constrain the mode to HTTP 1.1.- Returns:
- The version selection for WebSocket
 
- 
forClientConfigurationpublic static HttpVersionSelection forClientConfiguration(HttpClientConfiguration clientConfiguration) Construct a version selection from the given client configuration.- Parameters:
- clientConfiguration- The client configuration
- Returns:
- The configured version selection
 
- 
forClientAnnotation@Internal @Nullable public static @Nullable HttpVersionSelection forClientAnnotation(AnnotationMetadata metadata) Infer the version selection for the givenClientannotation, if any version settings are set.- Parameters:
- metadata- The annotation metadata possibly containing a- Clientannotation
- Returns:
- The configured version selection, or nullif the version is not explicitly set and should be inherited from the normal configuration instead.
 
- 
getPlaintextMode- Returns:
- Connection mode to use for plaintext connections
 
- 
getAlpnSupportedProtocols- Returns:
- Protocols that should be shown as supported via ALPN
 
- 
isAlpn- Returns:
- Whether ALPN should be used
 
- 
isHttp2CipherSuites- Returns:
- Whether TLS cipher suites should be constrained to those defined by the HTTP/2 spec
 
- 
isHttp3
- 
equals
- 
hashCodepublic int hashCode()
 
-