Class LimitsFeatureConfig.BuilderBase<BUILDER extends LimitsFeatureConfig.BuilderBase<BUILDER,PROTOTYPE>,PROTOTYPE extends LimitsFeatureConfig>

java.lang.Object
io.helidon.webserver.concurrency.limits.LimitsFeatureConfig.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>, Prototype.ConfiguredBuilder<BUILDER,PROTOTYPE>
Direct Known Subclasses:
LimitsFeatureConfig.Builder
Enclosing interface:
LimitsFeatureConfig

public abstract static class LimitsFeatureConfig.BuilderBase<BUILDER extends LimitsFeatureConfig.BuilderBase<BUILDER,PROTOTYPE>,PROTOTYPE extends LimitsFeatureConfig> extends Object implements Prototype.ConfiguredBuilder<BUILDER,PROTOTYPE>
Fluent API builder base for LimitsFeature.
  • Constructor Details

    • BuilderBase

      protected BuilderBase()
      Protected to support extensibility.
  • Method Details

    • from

      public BUILDER from(LimitsFeatureConfig prototype)
      Update 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
    • from

      public BUILDER from(LimitsFeatureConfig.BuilderBase<?,?> builder)
      Update this builder from an existing prototype builder instance.
      Parameters:
      builder - existing builder prototype to update this builder from
      Returns:
      updated builder instance
    • config

      public BUILDER config(Config config)
      Update builder from configuration (node of this type). If a value is present in configuration, it would override currently configured values.
      Specified by:
      config in interface Prototype.ConfiguredBuilder<BUILDER extends LimitsFeatureConfig.BuilderBase<BUILDER,PROTOTYPE>,PROTOTYPE extends LimitsFeatureConfig>
      Parameters:
      config - configuration instance used to obtain values to update this builder
      Returns:
      updated builder instance
    • weight

      public BUILDER weight(double weight)
      Weight of the context feature. As it is used by other features, the default is quite high: 2000.0.
      Parameters:
      weight - weight of the feature
      Returns:
      updated builder instance
      See Also:
    • sockets

      public BUILDER sockets(Set<? extends String> sockets)
      List of sockets to register this feature on. If empty, it would get registered on all sockets.
      Parameters:
      sockets - socket names to register on, defaults to empty (all available sockets)
      Returns:
      updated builder instance
      See Also:
    • addSockets

      public BUILDER addSockets(Set<? extends String> sockets)
      List of sockets to register this feature on. If empty, it would get registered on all sockets.
      Parameters:
      sockets - socket names to register on, defaults to empty (all available sockets)
      Returns:
      updated builder instance
      See Also:
    • name

      public BUILDER name(String name)
      Name of this instance.
      Parameters:
      name - instance name
      Returns:
      updated builder instance
      See Also:
    • clearConcurrencyLimit

      public BUILDER clearConcurrencyLimit()
      Clear existing value of this property.
      Returns:
      updated builder instance
      See Also:
    • concurrencyLimit

      public BUILDER concurrencyLimit(Limit concurrencyLimit)
      Concurrency limit to use to limit concurrent execution of incoming requests. The default is to have unlimited concurrency.
      Parameters:
      concurrencyLimit - concurrency limit
      Returns:
      updated builder instance
      See Also:
    • enabled

      public BUILDER enabled(boolean enabled)
      Whether this feature is enabled, defaults to true.
      Parameters:
      enabled - whether to enable this feature
      Returns:
      updated builder instance
      See Also:
    • weight

      public double weight()
      Weight of the context feature. As it is used by other features, the default is quite high: 2000.0.
      Returns:
      the weight
    • sockets

      public Set<String> sockets()
      List of sockets to register this feature on. If empty, it would get registered on all sockets.
      Returns:
      the sockets
    • name

      public String name()
      Name of this instance.
      Returns:
      the name
    • concurrencyLimit

      public Optional<Limit> concurrencyLimit()
      Concurrency limit to use to limit concurrent execution of incoming requests. The default is to have unlimited concurrency.
      Returns:
      the concurrency limit
    • enabled

      public boolean enabled()
      Whether this feature is enabled, defaults to true.
      Returns:
      the enabled
    • config

      public Optional<Config> config()
      If 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

      public String toString()
      Overrides:
      toString in class Object
    • preBuildPrototype

      protected void preBuildPrototype()
      Handles providers and decorators.
    • validatePrototype

      protected void validatePrototype()
      Validates required properties.