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

com.clickhouse.client.cli.config.ClickHouseCommandLineOption Maven / Gradle / Ivy

Go to download

Wrapper of ClickHouse native command-line client planed to be deprecated from version 0.6.0 and removed at 0.7.0

There is a newer version: 0.6.4
Show newest version
package com.clickhouse.client.cli.config;

import java.io.Serializable;

import com.clickhouse.config.ClickHouseOption;
import com.clickhouse.data.ClickHouseChecker;

public enum ClickHouseCommandLineOption implements ClickHouseOption {
    /**
     * ClickHouse native command-line client path. Empty value is treated as
     * 'clickhouse'.
     */
    CLICKHOUSE_CLI_PATH("clickhouse_cli_path", "",
            "ClickHouse native command-line client path, empty value is treated as 'clickhouse'"),
    /**
     * ClickHouse docker image. Empty value is treated as
     * 'clickhouse/clickhouse-server'.
     */
    CLICKHOUSE_DOCKER_IMAGE("clickhouse_docker_image", "clickhouse/clickhouse-server",
            "ClickHouse docker image, empty value is treated as 'clickhouse/clickhouse-server'"),
    /**
     * Docker command-line path. Empty value is treated as 'docker'.
     */
    DOCKER_CLI_PATH("docker_cli_path", "", "Docker command-line path, empty value is treated as 'docker'"),
    /**
     * ClickHouse native command-line client configuration file. Empty value will
     * disable {@link #USE_CLI_CONFIG}.
     */
    CLI_CONFIG_FILE("cli_config_file", "~/.clickhouse-client/config.xml",
            "ClickHouse native command-line client configuration file, empty value will disable 'use_cli_config'"),
    /**
     * Docker container ID or name. Empty value will result in new container being
     * created for each query.
     */
    CLI_CONTAINER_ID("cli_container_id", "clickhouse-cli-client",
            "Docker container ID or name, empty value will result in new container being created for each query"),
    /**
     * Work directory inside container, only works running in docker mode(when
     * {@link #CLICKHOUSE_CLI_PATH} is not available). Empty value is treated as
     * '/tmp'.
     */
    CLI_CONTAINER_DIRECTORY("cli_container_directory", "",
            "Work directory inside container, empty value is treated as '/tmp'"),
    /**
     * Command-line work directory. Empty value is treated as system temporary
     * directory(e.g. {@code System.getProperty("java.io.tmpdir")}). When running in
     * docker mode, it's mounted as {@link #CLI_CONTAINER_DIRECTORY} in container.
     */
    CLI_WORK_DIRECTORY("cli_work_directory", "",
            "Command-line work directory, empty value is treate as system temporary directory"),
    /**
     * Whether to use native command-line client configuration file as defined in
     * {@link #CLI_CONFIG_FILE}.
     */
    USE_CLI_CONFIG("use_cli_config", false,
            "Whether to use native command-line client configuration file as defined in 'cli_config_file'"),
    /**
     * Whether to use profile events or not. This is needed when you want to get
     * meaningful response summary.
     */
    USE_PROFILE_EVENTS("use_profile_events", false, "Whether to use profile events or not");

    private final String key;
    private final Serializable defaultValue;
    private final Class clazz;
    private final String description;
    private final boolean sensitive;

     ClickHouseCommandLineOption(String key, T defaultValue, String description) {
        this(key, defaultValue, description, false);
    }

     ClickHouseCommandLineOption(String key, T defaultValue, String description,
            boolean sensitive) {
        this.key = ClickHouseChecker.nonNull(key, "key");
        this.defaultValue = ClickHouseChecker.nonNull(defaultValue, "defaultValue");
        this.clazz = defaultValue.getClass();
        this.description = ClickHouseChecker.nonNull(description, "description");
        this.sensitive = sensitive;
    }

    @Override
    public Serializable getDefaultValue() {
        return defaultValue;
    }

    @Override
    public String getDescription() {
        return description;
    }

    @Override
    public String getKey() {
        return key;
    }

    @Override
    public Class getValueType() {
        return clazz;
    }

    @Override
    public boolean isSensitive() {
        return sensitive;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy