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

datahub.client.rest.RestEmitterConfig Maven / Gradle / Ivy

package datahub.client.rest;

import datahub.event.EventFormatter;
import java.io.InputStream;
import java.util.Collections;
import java.util.Map;
import java.util.Properties;
import java.util.function.Consumer;
import lombok.Builder;
import lombok.NonNull;
import lombok.Value;
import lombok.extern.slf4j.Slf4j;
import org.apache.hc.client5.http.config.RequestConfig;
import org.apache.hc.client5.http.impl.async.HttpAsyncClientBuilder;
import org.apache.hc.client5.http.impl.async.HttpAsyncClients;
import org.apache.hc.core5.util.TimeValue;

@Value
@Builder
@Slf4j
public class RestEmitterConfig {

  public static final int DEFAULT_CONNECT_TIMEOUT_SEC = 10;
  public static final int DEFAULT_READ_TIMEOUT_SEC = 10;
  public static final String DEFAULT_AUTH_TOKEN = null;
  public static final String CLIENT_VERSION_PROPERTY = "clientVersion";

  @Builder.Default String server = "http://localhost:8080";

  Integer timeoutSec;
  @Builder.Default boolean disableSslVerification = false;

  @Builder.Default boolean disableChunkedEncoding = false;

  @Builder.Default int maxRetries = 0;

  @Builder.Default int retryIntervalSec = 10;

  @Builder.Default String token = DEFAULT_AUTH_TOKEN;

  @Builder.Default @NonNull Map extraHeaders = Collections.EMPTY_MAP;

  @Builder.Default
  EventFormatter eventFormatter = new EventFormatter(EventFormatter.Format.PEGASUS_JSON);

  HttpAsyncClientBuilder asyncHttpClientBuilder;

  public static class RestEmitterConfigBuilder {

    private String getVersion() {
      try (InputStream foo =
          this.getClass().getClassLoader().getResourceAsStream("client.properties")) {
        Properties properties = new Properties();
        properties.load(foo);
        return properties.getProperty(CLIENT_VERSION_PROPERTY, "unknown");
      } catch (Exception e) {
        log.warn("Unable to find a version for datahub-client. Will set to unknown", e);
        return "unknown";
      }
    }

    private HttpAsyncClientBuilder asyncHttpClientBuilder =
        HttpAsyncClients.custom()
            .setUserAgent("DataHub-RestClient/" + getVersion())
            .setDefaultRequestConfig(
                RequestConfig.custom()
                    .setConnectionRequestTimeout(
                        DEFAULT_CONNECT_TIMEOUT_SEC * 1000,
                        java.util.concurrent.TimeUnit.MILLISECONDS)
                    .setResponseTimeout(
                        DEFAULT_READ_TIMEOUT_SEC * 1000, java.util.concurrent.TimeUnit.MILLISECONDS)
                    .build())
            .setRetryStrategy(
                new DatahubHttpRequestRetryStrategy(
                    maxRetries$value, TimeValue.ofSeconds(retryIntervalSec$value)));

    public RestEmitterConfigBuilder with(Consumer builderFunction) {
      builderFunction.accept(this);
      return this;
    }

    public RestEmitterConfigBuilder customizeHttpAsyncClient(
        Consumer asyncClientBuilderFunction) {
      asyncClientBuilderFunction.accept(this.asyncHttpClientBuilder);
      return this;
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy