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

java.lang.Object
io.helidon.telemetry.otelconfig.ProcessorConfig.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:
BatchProcessorConfig.BuilderBase, ProcessorConfig.Builder
Enclosing interface:
ProcessorConfig

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

    • BuilderBase

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

    • from

      public BUILDER from(ProcessorConfig 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(ProcessorConfig.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

      @Deprecated 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 ConfigBuilderSupport.ConfiguredBuilder<BUILDER extends ProcessorConfig.BuilderBase<BUILDER,PROTOTYPE>,PROTOTYPE extends ProcessorConfig>
      Parameters:
      config - configuration instance used to obtain values to update this builder
      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 ConfigBuilderSupport.ConfiguredBuilder<BUILDER extends ProcessorConfig.BuilderBase<BUILDER,PROTOTYPE>,PROTOTYPE extends ProcessorConfig>
      Parameters:
      config - configuration instance used to obtain values to update this builder
      Returns:
      updated builder instance
    • clearExporters

      public BUILDER clearExporters()
      Clear all exporters.
      Returns:
      updated builder instance
      See Also:
    • exporters

      public BUILDER exporters(List<String> exporters)
      Name(s) of the exporter(s) this processor should use; specifying no names uses all configured exporters (or if no exporters are configured, the default OpenTelemetry exporter(s)).

      Each name must be the name of one of the configured OpenTelemetryTracingConfig.exporterConfigs().

      Parameters:
      exporters - exporter name
      Returns:
      updated builder instance
      See Also:
    • addExporters

      public BUILDER addExporters(List<String> exporters)
      Name(s) of the exporter(s) this processor should use; specifying no names uses all configured exporters (or if no exporters are configured, the default OpenTelemetry exporter(s)).

      Each name must be the name of one of the configured OpenTelemetryTracingConfig.exporterConfigs().

      Parameters:
      exporters - exporter name
      Returns:
      updated builder instance
      See Also:
    • type

      public BUILDER type(ProcessorType type)
      Processor type.
      Parameters:
      type - processor type
      Returns:
      updated builder instance
      See Also:
    • exporters

      public List<String> exporters()
      Name(s) of the exporter(s) this processor should use; specifying no names uses all configured exporters (or if no exporters are configured, the default OpenTelemetry exporter(s)).

      Each name must be the name of one of the configured OpenTelemetryTracingConfig.exporterConfigs().

      Returns:
      exporter name
    • type

      public Optional<ProcessorType> type()
      Processor type.
      Returns:
      processor type
    • toString

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

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

      protected void validatePrototype()
      Validates required properties.
    • config

      protected Optional<Config> config()
      Configuration used to configure this instance.
      Returns:
      config instance