Interface WsClientConfig

All Superinterfaces:
HttpClientConfig, HttpConfigBase, Prototype.Api, Prototype.Factory<WsClient>
All Known Implementing Classes:
WsClientConfig.BuilderBase.WsClientConfigImpl

public interface WsClientConfig extends Prototype.Api, HttpClientConfig
WebSocket full webclient configuration. The client configuration also contains all necessary configuration for HTTP, as WebSocket upgrades from HTTP.
See Also:
  • Method Details Link icon

    • builder Link icon

      static WsClientConfig.Builder builder()
      Create a new fluent API builder to customize configuration.
      Returns:
      a new builder
    • builder Link icon

      static WsClientConfig.Builder builder(WsClientConfig instance)
      Create a new fluent API builder from an existing instance.
      Parameters:
      instance - an existing instance used as a base for the builder
      Returns:
      a builder based on an instance
    • create Link icon

      static WsClientConfig create(Config config)
      Create a new instance from configuration.
      Parameters:
      config - used to configure the new instance
      Returns:
      a new instance configured from configuration
    • create Link icon

      static WsClientConfig create()
      Create a new instance with default values.
      Returns:
      a new instance
    • protocolConfig Link icon

      WsClientProtocolConfig protocolConfig()
      WebSocket specific configuration.
      Returns:
      protocol specific configuration
    • baseUri Link icon

      Optional<ClientUri> baseUri()
      Base uri used by the client in all requests.
      Returns:
      base uri of the client requests
    • baseQuery Link icon

      Optional<UriQuery> baseQuery()
      Base query used by the client in all requests.
      Returns:
      base query of the client requests
    • baseFragment Link icon

      Optional<UriFragment> baseFragment()
      Base fragment used by the client in all requests (unless overwritten on per-request basis).
      Returns:
      fragment to use
    • socketOptions Link icon

      SocketOptions socketOptions()
      Socket options for connections opened by this client. If there is a value explicitly configured on this type and on the socket options, the one configured on this type's builder will win:
      Returns:
      socket options
    • dnsResolver Link icon

      DnsResolver dnsResolver()
      DNS resolver to be used by this client.
      Returns:
      dns resolver
    • dnsAddressLookup Link icon

      DnsAddressLookup dnsAddressLookup()
      DNS address lookup preferences to be used by this client. Default value is determined by capabilities of the system.
      Returns:
      dns address lookup strategy
    • defaultHeadersMap Link icon

      Map<String,String> defaultHeadersMap()
      Default headers to be used in every request from configuration.
      Returns:
      default headers
    • headers Link icon

      Set<Header> headers()
      Default headers to be used in every request.
      Returns:
      default headers
    • defaultRequestHeaders Link icon

      default ClientRequestHeaders defaultRequestHeaders()
      Default headers as a headers object. Creates a new instance for each call, so the returned value can be safely mutated.
      Returns:
      default headers
    • mediaTypeParserMode Link icon

      ParserMode mediaTypeParserMode()
      Configure media type parsing mode for HTTP Content-Type header.
      Returns:
      media type parsing mode
    • contentEncoding Link icon

      ContentEncodingContext contentEncoding()
      Configure the listener specific ContentEncodingContext. This method discards all previously registered ContentEncodingContext. If no content encoding context is registered, default encoding context is used.
      Returns:
      content encoding context
    • mediaContext Link icon

      MediaContext mediaContext()
      Configure the listener specific MediaContext. This method discards all previously registered MediaContext. If no media context is registered, default media context is used.
      Returns:
      media context
    • mediaSupports Link icon

      List<MediaSupport> mediaSupports()
      Media supports (manually added). If both mediaContext() and this is configured, there will be a new context created from return of this method, with fallback of mediaContext().
      Returns:
      list of explicitly added media supports
    • services Link icon

      List<WebClientService> services()
      WebClient services.
      Returns:
      services to use with this web client
    • relativeUris Link icon

      boolean relativeUris()
      Can be set to true to force the use of relative URIs in all requests, regardless of the presence or absence of proxies or no-proxy lists.
      Returns:
      relative URIs flag
    • executor Link icon

      ExecutorService executor()
      Client executor service.
      Returns:
      executor service to use when needed (such as for HTTP/2)
    • sendExpectContinue Link icon

      boolean sendExpectContinue()
      Whether Expect-100-Continue header is sent to verify server availability before sending an entity.

      Defaults to true.

      Returns:
      whether Expect:100-Continue header should be sent on streamed transfers
    • connectionCacheSize Link icon

      int connectionCacheSize()
      Maximal size of the connection cache. For most HTTP protocols, we may cache connections to various endpoints for keep alive (or stream reuse in case of HTTP/2). This option limits the size. Setting this number lower than the "usual" number of target services will cause connections to be closed and reopened frequently.
    • cookieManager Link icon

      WebClient cookie manager.
      Returns:
      cookie manager to use
    • readContinueTimeout Link icon

      Duration readContinueTimeout()
      Socket 100-Continue read timeout. Default is 1 second. This read timeout is used when 100-Continue is sent by the client, before it sends an entity.
      Returns:
      read 100-Continue timeout duration
    • shareConnectionCache Link icon

      boolean shareConnectionCache()
      Whether to share connection cache between all the WebClient instances in JVM.
      Returns:
      true if connection cache is shared
    • maxInMemoryEntity Link icon

      int maxInMemoryEntity()
      If the entity is expected to be smaller that this number of bytes, it would be buffered in memory to optimize performance. If bigger, streaming will be used.

      Note that for some entity types we cannot use streaming, as they are already fully in memory (String, byte[]), for such cases, this option is ignored. Default is 128Kb.

      Returns:
      maximal number of bytes to buffer in memory for supported writers
    • followRedirects Link icon

      boolean followRedirects()
      Whether to follow redirects.
      Returns:
      whether to follow redirects
    • maxRedirects Link icon

      int maxRedirects()
      Max number of followed redirects. This is ignored if followRedirects() option is false.
      Returns:
      max number of followed redirects
    • tls Link icon

      Tls tls()
      TLS configuration for any TLS request from this client. TLS can also be configured per request. TLS is used when the protocol is set to https.
      Returns:
      TLS configuration to use
    • readTimeout Link icon

      Optional<Duration> readTimeout()
      Read timeout.
      Returns:
      read timeout
      See Also:
      • SocketOptionsBlueprint.readTimeout()
    • connectTimeout Link icon

      Optional<Duration> connectTimeout()
      Connect timeout.
      Returns:
      connect timeout
      See Also:
      • SocketOptionsBlueprint.connectTimeout()
    • keepAlive Link icon

      boolean keepAlive()
      Determines if connection keep alive is enabled (NOT socket keep alive, but HTTP connection keep alive, to re-use the same connection for multiple requests).
      Returns:
      keep alive for this connection
      See Also:
      • SocketOptionsBlueprint.socketKeepAlive()
    • proxy Link icon

      Proxy proxy()
      Proxy configuration to be used for requests.
      Returns:
      proxy to use, defaults to Proxy.noProxy()
    • properties Link icon

      Map<String,String> properties()
      Properties configured for this client. These properties are propagated through client request, to be used by services (and possibly for other purposes).
      Returns:
      map of client properties