Module io.helidon.webclient.grpc
Package io.helidon.webclient.grpc
Class GrpcClientProtocolConfig.BuilderBase<BUILDER extends GrpcClientProtocolConfig.BuilderBase<BUILDER,PROTOTYPE>,PROTOTYPE extends GrpcClientProtocolConfig>  
java.lang.Object
io.helidon.webclient.grpc.GrpcClientProtocolConfig.BuilderBase<BUILDER,PROTOTYPE> 
- Type Parameters:
- BUILDER- type of the builder extending this abstract builder
- PROTOTYPE- type of the prototype interface that would be built by- Prototype.Builder.buildPrototype()
- All Implemented Interfaces:
- Prototype.Builder<BUILDER,,- PROTOTYPE> - ConfigBuilderSupport.ConfiguredBuilder<BUILDER,,- PROTOTYPE> - ConfigBuilderSupport.ConfiguredBuilder<BUILDER,- PROTOTYPE> 
- Direct Known Subclasses:
- GrpcClientProtocolConfig.Builder
- Enclosing interface:
- GrpcClientProtocolConfig
public abstract static class GrpcClientProtocolConfig.BuilderBase<BUILDER extends GrpcClientProtocolConfig.BuilderBase<BUILDER,PROTOTYPE>,PROTOTYPE extends GrpcClientProtocolConfig>  
extends Object
implements ConfigBuilderSupport.ConfiguredBuilder<BUILDER,PROTOTYPE> 
Fluent API builder base for 
GrpcClientProtocolConfig.- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionprotected static classGenerated implementation of the prototype, can be extended by descendant prototype implementations.
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionbooleanWhether to continue retrying after a poll wait timeout expired or not.abortPollTimeExpired(boolean abortPollTimeExpired) Whether to continue retrying after a poll wait timeout expired or not.config()If this instance was configured, this would be the config instance used.Deprecated.Update builder from configuration (node of this type).from(GrpcClientProtocolConfig prototype) Update this builder from an existing prototype instance.from(GrpcClientProtocolConfig.BuilderBase<?, ?> builder) Update this builder from an existing prototype builder instance.How often to send a heartbeat (HTTP/2 ping) to check if the connection is still alive.heartbeatPeriod(Duration heartbeatPeriod) How often to send a heartbeat (HTTP/2 ping) to check if the connection is still alive.intInitial buffer size used to serialize gRPC request payloads.initBufferSize(int initBufferSize) Initial buffer size used to serialize gRPC request payloads.name()Name identifying this client protocol.Name identifying this client protocol.When data has been received from the server but not yet requested by the client (i.e., listener), the implementation will wait for this duration before signaling an error.nextRequestWaitTime(Duration nextRequestWaitTime) When data has been received from the server but not yet requested by the client (i.e., listener), the implementation will wait for this duration before signaling an error.How long to wait for the next HTTP/2 data frame to arrive in underlying stream.pollWaitTime(Duration pollWaitTime) How long to wait for the next HTTP/2 data frame to arrive in underlying stream.protected voidHandles providers and decorators.toString()protected voidValidates required properties.Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface io.helidon.builder.api.Prototype.BuilderbuildPrototype, self
- 
Constructor Details- 
BuilderBaseprotected BuilderBase()Protected to support extensibility.
 
- 
- 
Method Details- 
fromUpdate this builder from an existing prototype instance. This method disables automatic service discovery.- Parameters:
- prototype- existing prototype to update this builder from
- Returns:
- updated builder instance
 
- 
fromUpdate this builder from an existing prototype builder instance.- Parameters:
- builder- existing builder prototype to update this builder from
- Returns:
- updated builder instance
 
- 
configDeprecated.Update builder from configuration (node of this type). If a value is present in configuration, it would override currently configured values.- Specified by:
- configin interface- ConfigBuilderSupport.ConfiguredBuilder<BUILDER extends GrpcClientProtocolConfig.BuilderBase<BUILDER,- PROTOTYPE>, - PROTOTYPE extends GrpcClientProtocolConfig> 
- Parameters:
- config- configuration instance used to obtain values to update this builder
- Returns:
- updated builder instance
 
- 
configUpdate builder from configuration (node of this type). If a value is present in configuration, it would override currently configured values.- Specified by:
- configin interface- ConfigBuilderSupport.ConfiguredBuilder<BUILDER extends GrpcClientProtocolConfig.BuilderBase<BUILDER,- PROTOTYPE>, - PROTOTYPE extends GrpcClientProtocolConfig> 
- Parameters:
- config- configuration instance used to obtain values to update this builder
- Returns:
- updated builder instance
 
- 
nameName identifying this client protocol. Defaults to type.- Parameters:
- name- name of client protocol
- Returns:
- updated builder instance
- See Also:
 
- 
pollWaitTimeHow long to wait for the next HTTP/2 data frame to arrive in underlying stream. Whether this is a fatal error or not is controlled byabortPollTimeExpired().- Parameters:
- pollWaitTime- poll time as a duration
- Returns:
- updated builder instance
- See Also:
 
- 
abortPollTimeExpiredWhether to continue retrying after a poll wait timeout expired or not. If a read operation timeouts out and this flag is set tofalse, the event is logged and the client will retry. Otherwise, an exception is thrown.- Parameters:
- abortPollTimeExpired- abort timeout flag
- Returns:
- updated builder instance
- See Also:
 
- 
heartbeatPeriodHow often to send a heartbeat (HTTP/2 ping) to check if the connection is still alive. This is useful for long-running, streaming gRPC calls. It is turned off by default but can be enabled by setting the period to a value greater than 0.- Parameters:
- heartbeatPeriod- heartbeat period
- Returns:
- updated builder instance
- See Also:
 
- 
initBufferSizeInitial buffer size used to serialize gRPC request payloads. Buffers shall grow according to the payload size, but setting this initial buffer size to a larger value may improve performance for certain applications.- Parameters:
- initBufferSize- initial buffer size
- Returns:
- updated builder instance
- See Also:
 
- 
nextRequestWaitTimeWhen data has been received from the server but not yet requested by the client (i.e., listener), the implementation will wait for this duration before signaling an error. If data is requested and more data is still in the queue, this time wait restarts until the next request is received. If duration expires, a status ofStatus.CANCELLEDis reported in the call toClientCall.Listener.onClose(io.grpc.Status, io.grpc.Metadata).- Parameters:
- nextRequestWaitTime- duration to wait for the next data request from listener
- Returns:
- updated builder instance
- See Also:
 
- 
nameName identifying this client protocol. Defaults to type.- Returns:
- the name
 
- 
pollWaitTimeHow long to wait for the next HTTP/2 data frame to arrive in underlying stream. Whether this is a fatal error or not is controlled byabortPollTimeExpired().- Returns:
- the poll wait time
- See Also:
 
- 
abortPollTimeExpiredpublic boolean abortPollTimeExpired()Whether to continue retrying after a poll wait timeout expired or not. If a read operation timeouts out and this flag is set tofalse, the event is logged and the client will retry. Otherwise, an exception is thrown.- Returns:
- the abort poll time expired
 
- 
heartbeatPeriodHow often to send a heartbeat (HTTP/2 ping) to check if the connection is still alive. This is useful for long-running, streaming gRPC calls. It is turned off by default but can be enabled by setting the period to a value greater than 0.- Returns:
- the heartbeat period
 
- 
initBufferSizepublic int initBufferSize()Initial buffer size used to serialize gRPC request payloads. Buffers shall grow according to the payload size, but setting this initial buffer size to a larger value may improve performance for certain applications.- Returns:
- the init buffer size
 
- 
nextRequestWaitTimeWhen data has been received from the server but not yet requested by the client (i.e., listener), the implementation will wait for this duration before signaling an error. If data is requested and more data is still in the queue, this time wait restarts until the next request is received. If duration expires, a status ofStatus.CANCELLEDis reported in the call toClientCall.Listener.onClose(io.grpc.Status, io.grpc.Metadata).- Returns:
- the next request wait time
- See Also:
 
- 
configIf this instance was configured, this would be the config instance used.- Returns:
- config node used to configure this builder, or empty if not configured
 
- 
toString
- 
preBuildPrototypeprotected void preBuildPrototype()Handles providers and decorators.
- 
validatePrototypeprotected void validatePrototype()Validates required properties.
 
- 
config(io.helidon.config.Config)