All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.launchdarkly.sdk.server.LDConfig Maven / Gradle / Ivy

package com.launchdarkly.sdk.server;

import com.launchdarkly.sdk.EvaluationReason;
import com.launchdarkly.sdk.EvaluationReason.BigSegmentsStatus;
import com.launchdarkly.sdk.server.integrations.ApplicationInfoBuilder;
import com.launchdarkly.sdk.server.integrations.ServiceEndpointsBuilder;
import com.launchdarkly.sdk.server.interfaces.ApplicationInfo;
import com.launchdarkly.sdk.server.interfaces.BigSegmentsConfiguration;
import com.launchdarkly.sdk.server.interfaces.ServiceEndpoints;
import com.launchdarkly.sdk.server.subsystems.ComponentConfigurer;
import com.launchdarkly.sdk.server.subsystems.DataSource;
import com.launchdarkly.sdk.server.subsystems.DataStore;
import com.launchdarkly.sdk.server.subsystems.EventProcessor;
import com.launchdarkly.sdk.server.subsystems.HttpConfiguration;
import com.launchdarkly.sdk.server.subsystems.LoggingConfiguration;

import java.time.Duration;

/**
 * This class exposes advanced configuration options for the {@link LDClient}. Instances of this class must be constructed with a {@link com.launchdarkly.sdk.server.LDConfig.Builder}.
 */
public final class LDConfig {
  /**
   * The default value for {@link Builder#startWait(Duration)}: 5 seconds.
   */
  public static final Duration DEFAULT_START_WAIT = Duration.ofSeconds(5);
  
  protected static final LDConfig DEFAULT = new Builder().build();

  final ApplicationInfo applicationInfo;
  final ComponentConfigurer bigSegments;
  final ComponentConfigurer dataSource;
  final ComponentConfigurer dataStore;
  final boolean diagnosticOptOut;
  final ComponentConfigurer events;
  final ComponentConfigurer http;
  final ComponentConfigurer logging;
  final ServiceEndpoints serviceEndpoints;
  final boolean offline;
  final Duration startWait;
  final int threadPriority;

  protected LDConfig(Builder builder) {
    if (builder.offline) {
      this.dataSource = Components.externalUpdatesOnly();
      this.events = Components.noEvents();
    } else {
      this.dataSource = builder.dataSource == null ? Components.streamingDataSource() : builder.dataSource;
      this.events = builder.events == null ? Components.sendEvents() : builder.events;
    }
    this.applicationInfo = (builder.applicationInfoBuilder == null ? Components.applicationInfo() :
      builder.applicationInfoBuilder)
      .createApplicationInfo();
    this.bigSegments = builder.bigSegments == null ? Components.bigSegments(null) : builder.bigSegments;
    this.dataStore = builder.dataStore == null ? Components.inMemoryDataStore() : builder.dataStore;
    this.diagnosticOptOut = builder.diagnosticOptOut;
    this.http = builder.http == null ? Components.httpConfiguration() : builder.http;
    this.logging = builder.logging == null ? Components.logging() : builder.logging;
    this.offline = builder.offline;
    this.serviceEndpoints = (builder.serviceEndpointsBuilder == null ? Components.serviceEndpoints() :
      builder.serviceEndpointsBuilder)
      .createServiceEndpoints();
    this.startWait = builder.startWait;
    this.threadPriority = builder.threadPriority;
  }
  
  /**
   * A builder that helps construct
   * {@link com.launchdarkly.sdk.server.LDConfig} objects. Builder calls can be chained, enabling the
   * following pattern:
   * 
   * LDConfig config = new LDConfig.Builder()
   *      .connectTimeoutMillis(3)
   *      .socketTimeoutMillis(3)
   *      .build()
   * 
*/ public static class Builder { private ApplicationInfoBuilder applicationInfoBuilder = null; private ComponentConfigurer bigSegments = null; private ComponentConfigurer dataSource = null; private ComponentConfigurer dataStore = null; private boolean diagnosticOptOut = false; private ComponentConfigurer events = null; private ComponentConfigurer http = null; private ComponentConfigurer logging = null; private ServiceEndpointsBuilder serviceEndpointsBuilder = null; private boolean offline = false; private Duration startWait = DEFAULT_START_WAIT; private int threadPriority = Thread.MIN_PRIORITY; /** * Creates a builder with all configuration parameters set to the default */ public Builder() { } /** * Sets the SDK's application metadata, which may be used in LaunchDarkly analytics or other product features, * but does not affect feature flag evaluations. *

* This object is normally a configuration builder obtained from {@link Components#applicationInfo()}, * which has methods for setting individual logging-related properties. * * @param applicationInfoBuilder a configuration builder object returned by {@link Components#applicationInfo()} * @return the builder * @since 5.8.0 */ public Builder applicationInfo(ApplicationInfoBuilder applicationInfoBuilder) { this.applicationInfoBuilder = applicationInfoBuilder; return this; } /** * Sets the configuration of the SDK's Big Segments feature. *

* Big Segments are a specific type of user segments. For more information, read the * LaunchDarkly documentation * . *

* If you are using this feature, you will normally specify a database implementation that * matches how the LaunchDarkly Relay Proxy is configured, since the Relay Proxy manages the * Big Segment data. *

* By default, there is no implementation and Big Segments cannot be evaluated. In this case, * any flag evaluation that references a Big Segment will behave as if no users are included in * any Big Segments, and the {@link EvaluationReason} associated with any such flag evaluation * will have a {@link BigSegmentsStatus} of {@link BigSegmentsStatus#NOT_CONFIGURED}. * *


     *     // This example uses the Redis integration
     *     LDConfig config = LDConfig.builder()
     *         .bigSegments(Components.bigSegments(Redis.dataStore().prefix("app1"))
     *             .userCacheSize(2000))
     *         .build();
     * 
* * @param bigSegmentsConfigurer the Big Segments configuration builder * @return the builder * @since 5.7.0 * @see Components#bigSegments(ComponentConfigurer) */ public Builder bigSegments(ComponentConfigurer bigSegmentsConfigurer) { this.bigSegments = bigSegmentsConfigurer; return this; } /** * Sets the implementation of the component that receives feature flag data from LaunchDarkly, * using a factory object. Depending on the implementation, the factory may be a builder that * allows you to set other configuration options as well. *

* The default is {@link Components#streamingDataSource()}. You may instead use * {@link Components#pollingDataSource()}, or a test fixture such as * {@link com.launchdarkly.sdk.server.integrations.FileData#dataSource()}. See those methods * for details on how to configure them. * * @param dataSourceConfigurer the data source configuration builder * @return the main configuration builder * @since 4.12.0 */ public Builder dataSource(ComponentConfigurer dataSourceConfigurer) { this.dataSource = dataSourceConfigurer; return this; } /** * Sets the implementation of the data store to be used for holding feature flags and * related data received from LaunchDarkly, using a factory object. The default is * {@link Components#inMemoryDataStore()}; for database integrations, use * {@link Components#persistentDataStore(ComponentConfigurer)}. * * @param dataStoreConfigurer the data store configuration builder * @return the main configuration builder * @since 4.12.0 */ public Builder dataStore(ComponentConfigurer dataStoreConfigurer) { this.dataStore = dataStoreConfigurer; return this; } /** * Set to true to opt out of sending diagnostics data. *

* Unless {@code diagnosticOptOut} is set to true, the client will send some diagnostics data to the * LaunchDarkly servers in order to assist in the development of future SDK improvements. These diagnostics * consist of an initial payload containing some details of SDK in use, the SDK's configuration, and the platform * the SDK is being run on; as well as payloads sent periodically with information on irregular occurrences such * as dropped events. * * @see com.launchdarkly.sdk.server.integrations.EventProcessorBuilder#diagnosticRecordingInterval(Duration) * * @param diagnosticOptOut true if you want to opt out of sending any diagnostics data * @return the builder * @since 4.12.0 */ public Builder diagnosticOptOut(boolean diagnosticOptOut) { this.diagnosticOptOut = diagnosticOptOut; return this; } /** * Sets the implementation of {@link EventProcessor} to be used for processing analytics events. *

* The default is {@link Components#sendEvents()} with no custom options. You may instead call * {@link Components#sendEvents()} and then set custom options for event processing; or, disable * events with {@link Components#noEvents()}; or, choose to use a custom implementation (for * instance, a test fixture). * * @param eventsConfigurer the events configuration builder * @return the main configuration builder * @since 4.12.0 * @see Components#sendEvents() * @see Components#noEvents() */ public Builder events(ComponentConfigurer eventsConfigurer) { this.events = eventsConfigurer; return this; } /** * Sets the SDK's networking configuration, using a configuration builder. This builder is * obtained from {@link Components#httpConfiguration()}, and has methods for setting individual * HTTP-related properties. * * @param httpConfigurer the HTTP configuration builder * @return the main configuration builder * @since 4.13.0 * @see Components#httpConfiguration() */ public Builder http(ComponentConfigurer httpConfigurer) { this.http = httpConfigurer; return this; } /** * Sets the SDK's logging configuration, using a factory object. This object is normally a * configuration builder obtained from {@link Components#logging()}, which has methods * for setting individual logging-related properties. * * @param loggingConfigurer the logging configuration builder * @return the main configuration builder * @since 5.0.0 * @see Components#logging() */ public Builder logging(ComponentConfigurer loggingConfigurer) { this.logging = loggingConfigurer; return this; } /** * Set whether this client is offline. *

* In offline mode, the SDK will not make network connections to LaunchDarkly for any purpose. Feature * flag data will only be available if it already exists in the data store, and analytics events will * not be sent. *

* This is equivalent to calling {@code dataSource(Components.externalUpdatesOnly())} and * {@code events(Components.noEvents())}. It overrides any other values you may have set for * {@link #dataSource(ComponentConfigurer)} or {@link #events(ComponentConfigurer)}. * * @param offline when set to true no calls to LaunchDarkly will be made * @return the builder */ public Builder offline(boolean offline) { this.offline = offline; return this; } /** * Sets the base service URIs used by SDK components. *

* This object is normally a configuration builder obtained from {@link Components#serviceEndpoints()}, * which has methods for setting each external endpoint to a custom URI. * * @param serviceEndpointsBuilder a configuration builder object returned by {@link Components#applicationInfo()} * @return the builder * @since 5.9.0 */ public Builder serviceEndpoints(ServiceEndpointsBuilder serviceEndpointsBuilder) { this.serviceEndpointsBuilder = serviceEndpointsBuilder; return this; } /** * Set how long the constructor will block awaiting a successful connection to LaunchDarkly. * Setting this to a zero or negative duration will not block and cause the constructor to return immediately. *

* The default is {@link #DEFAULT_START_WAIT}. * * @param startWait maximum time to wait; null to use the default * @return the builder */ public Builder startWait(Duration startWait) { this.startWait = startWait == null ? DEFAULT_START_WAIT : startWait; return this; } /** * Set the priority to use for all threads created by the SDK. *

* By default, the SDK's worker threads use {@code Thread.MIN_PRIORITY} so that they will yield to * application threads if the JVM is busy. You may increase this if you want the SDK to be prioritized * over some other low-priority tasks. *

* Values outside the range of [{@code Thread.MIN_PRIORITY}, {@code Thread.MAX_PRIORITY}] will be set * to the minimum or maximum. * * @param threadPriority the priority for SDK threads * @return the builder * @since 5.0.0 */ public Builder threadPriority(int threadPriority) { this.threadPriority = Math.max(Thread.MIN_PRIORITY, Math.min(Thread.MAX_PRIORITY, threadPriority)); return this; } /** * Builds the configured {@link com.launchdarkly.sdk.server.LDConfig} object. * * @return the {@link com.launchdarkly.sdk.server.LDConfig} configured by this builder */ public LDConfig build() { return new LDConfig(this); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy