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

com.cognite.client.config.ClientConfig Maven / Gradle / Ivy

package com.cognite.client.config;

import com.google.auto.value.AutoValue;
import com.google.common.base.Preconditions;

import java.io.Serializable;

import static com.google.common.base.Preconditions.checkArgument;

/**
 * This class captures the client configuration parameters.
 */
@AutoValue
public abstract class ClientConfig implements Serializable {
    /*
    API request identifiers
     */
    private final static String SDK_IDENTIFIER = "cognite-java-sdk-1.x.x";
    private final static String DEFAULT_APP_IDENTIFIER = "cognite-java-sdk";
    private final static String DEFAULT_SESSION_IDENTIFIER = "cognite-java-sdk";


    private final static UpsertMode DEFAULT_UPSERT_MODE = UpsertMode.UPDATE;
    private final static int DEFAULT_LIST_PARTITIONS = 8;

    // Thread pool capacity
    private final static int DEFAULT_CPU_THREADS = 8;

    // Connection retries
    private static final int DEFAULT_RETRIES = 5;
    private static final int MAX_RETRIES = 20;
    private static final int MIN_RETRIES = 1;

    // Max batch size when writing to Raw
    private static final int DEFAULT_WRITE_RAW_MAX_BATCH_SIZE = 2000;
    private static final int MIN_WRITE_RAW_MAX_BATCH_SIZE = 1;
    private static final int MAX_WRITE_RAW_MAX_BATCH_SIZE = 10000;

    // Max batch size for context operations
    private static final int DEFAULT_ENTITY_MATCHING_MAX_BATCH_SIZE = 1000;
    private static final int MIN_ENTITY_MATCHING_MAX_BATCH_SIZE = 1;
    private static final int MAX_ENTITY_MATCHING_MAX_BATCH_SIZE = 20000;

    private static Builder builder() {
        return new AutoValue_ClientConfig.Builder()
                .setSdkIdentifier(SDK_IDENTIFIER)
                .setAppIdentifier(DEFAULT_APP_IDENTIFIER)
                .setSessionIdentifier(DEFAULT_SESSION_IDENTIFIER)
                .setMaxRetries(DEFAULT_RETRIES)
                .setNoWorkers(DEFAULT_CPU_THREADS)
                .setNoListPartitions(DEFAULT_LIST_PARTITIONS)
                .setUpsertMode(DEFAULT_UPSERT_MODE)
                .setEntityMatchingMaxBatchSize(DEFAULT_ENTITY_MATCHING_MAX_BATCH_SIZE);
    }

    /**
     * Returns a {@link ClientConfig} object with default settings.
     *
     * @return the {@link ClientConfig} object.
     */
    public static ClientConfig create() {
        return ClientConfig.builder().build();
    }

    abstract Builder toBuilder();

    public abstract String getSdkIdentifier();
    public abstract String getAppIdentifier();
    public abstract String getSessionIdentifier();
    public abstract int getMaxRetries();
    public abstract int getNoWorkers();
    public abstract int getNoListPartitions();
    public abstract UpsertMode getUpsertMode();
    public abstract int getEntityMatchingMaxBatchSize();

    /**
     * Set the app identifier. The identifier is encoded in the api calls to the Cognite instance and can be
     * used for tracing and statistics.
     *
     * @param identifier the application identifier
     * @return the {@link ClientConfig} with the setting applied
     */
    public ClientConfig withAppIdentifier(String identifier) {
        Preconditions.checkNotNull(identifier, "Identifier cannot be null");
        Preconditions.checkArgument(!identifier.isEmpty(), "Identifier cannot be an empty string.");
        return toBuilder().setAppIdentifier(identifier).build();
    }

    /**
     * Set the session identifier. The identifier is encoded in the api calls to the Cognite instance and can be
     * used for tracing and statistics.
     *
     * @param identifier the session identifier
     * @return the {@link ClientConfig} with the setting applied
     */
    public ClientConfig withSessionIdentifier(String identifier) {
        Preconditions.checkNotNull(identifier, "Identifier cannot be null");
        Preconditions.checkArgument(!identifier.isEmpty(), "Identifier cannot be an empty string.");
        return toBuilder().setSessionIdentifier(identifier).build();
    }

    /**
     * Sets the maximum number of retries when sending requests to the Cognite API.
     *
     * The default setting is 5. This should be sufficient for most scenarios.
     *
     * @param retries the {@link ClientConfig} with the setting applied
     * @return the {@link ClientConfig} with the setting applied
     */
    public ClientConfig withMaxRetries(int retries) {
        Preconditions.checkArgument(retries <= MAX_RETRIES && retries >= MIN_RETRIES,
                String.format("The max number of retries must be between %d and %d", MIN_RETRIES, MAX_RETRIES));
        return toBuilder().setMaxRetries(retries).build();
    }

    /**
     * Specifies the maximum number of workers to use for the Cognite API requests. The default setting is
     * eight workers per (virtual) CPU core.
     *
     * @param noWorkers max number of workers
     * @return the {@link ClientConfig} with the setting applied
     */
    public ClientConfig withNoWorkers(int noWorkers) {
        return toBuilder().setNoWorkers(noWorkers).build();
    }

    /**
     * Specifies the number of partitions to use for (read) list requests. This represents the number
     * of parallel streams to use for reading the results of list requests.
     *
     * The default setting is eight partitions.
     *
     * @param noPartitions the number of partitions for list requests
     * @return the {@link ClientConfig} with the setting applied
     */
    public ClientConfig withNoListPartitions(int noPartitions) {
        return toBuilder().setNoListPartitions(noPartitions).build();
    }

    /**
     * Sets the upsert mode.
     *
     * When the data object to write does not exist, the writer will always create it. But, if the
     * object already exist, the writer can update the the existing object in one of two ways: update or replace.
     *
     * UpsertMode.UPDATE will update the provided fields in the target object--all other fields will remain
     * unchanged.
     *
     * UpsertMode.REPLACE will replace the entire target object with the provided fields
     * (id and externalId will remain unchanged).
     *
     * @param mode the upsert mode
     * @return the {@link ClientConfig} with the setting applied
     */
    public ClientConfig withUpsertMode(UpsertMode mode) {
        return toBuilder().setUpsertMode(mode).build();
    }

    /**
     * Sets the max batch size when executing entity matching operations.
     * @param value
     * @return
     */
    public ClientConfig withEntityMatchingMaxBatchSize(int value) {
        checkArgument(value >= MIN_ENTITY_MATCHING_MAX_BATCH_SIZE
                        && value <= MAX_ENTITY_MATCHING_MAX_BATCH_SIZE,
                String.format("Max context batch size must be between %d and %d", MIN_ENTITY_MATCHING_MAX_BATCH_SIZE,
                        MAX_ENTITY_MATCHING_MAX_BATCH_SIZE));

        return toBuilder().setEntityMatchingMaxBatchSize(value).build();
    }

    @AutoValue.Builder
    static abstract class Builder {
        abstract Builder setSdkIdentifier(String value);
        abstract Builder setAppIdentifier(String value);
        abstract Builder setSessionIdentifier(String value);
        abstract Builder setMaxRetries(int value);
        abstract Builder setNoWorkers(int value);
        abstract Builder setNoListPartitions(int value);
        abstract Builder setUpsertMode(UpsertMode value);
        abstract Builder setEntityMatchingMaxBatchSize(int value);

        abstract ClientConfig build();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy