org.graylog2.configuration.ElasticsearchClientConfiguration Maven / Gradle / Ivy
/*
* Copyright (C) 2020 Graylog, Inc.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the Server Side Public License, version 1,
* as published by MongoDB, Inc.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* Server Side Public License for more details.
*
* You should have received a copy of the Server Side Public License
* along with this program. If not, see
* .
*/
package org.graylog2.configuration;
import com.github.joschi.jadconfig.Parameter;
import com.github.joschi.jadconfig.util.Duration;
import com.github.joschi.jadconfig.validators.PositiveDurationValidator;
import com.github.joschi.jadconfig.validators.PositiveIntegerValidator;
import org.graylog2.configuration.converters.MajorVersionConverter;
import org.graylog2.configuration.converters.URIListConverter;
import org.graylog2.configuration.validators.ElasticsearchVersionValidator;
import org.graylog2.configuration.validators.HttpOrHttpsSchemeValidator;
import org.graylog2.configuration.validators.ListOfURIsWithHostAndSchemeValidator;
import org.graylog2.storage.SearchVersion;
import java.net.URI;
import java.util.ArrayList;
import java.util.List;
public class ElasticsearchClientConfiguration {
@Parameter(value = "elasticsearch_version", converter = MajorVersionConverter.class, validators = {ElasticsearchVersionValidator.class})
SearchVersion elasticsearchVersion;
@Parameter(value = "elasticsearch_hosts", converter = URIListConverter.class, validators = {ListOfURIsWithHostAndSchemeValidator.class})
List elasticsearchHosts = new ArrayList<>();
@Parameter(value = "elasticsearch_connect_timeout", validators = {PositiveDurationValidator.class})
Duration elasticsearchConnectTimeout = Duration.seconds(10);
@Parameter(value = "elasticsearch_socket_timeout", validators = {PositiveDurationValidator.class})
Duration elasticsearchSocketTimeout = Duration.seconds(60);
@Parameter(value = "elasticsearch_idle_timeout")
Duration elasticsearchIdleTimeout = Duration.seconds(-1L);
@Parameter(value = "elasticsearch_version_probe_attempts", validators = {PositiveIntegerValidator.class})
int elasticsearchVersionProbeAttempts = 0;
@Parameter(value = "elasticsearch_version_probe_delay", validators = {PositiveDurationValidator.class})
Duration elasticsearchVersionProbeDelay = Duration.seconds(5L);
@Parameter(value = "elasticsearch_max_total_connections", validators = {PositiveIntegerValidator.class})
int elasticsearchMaxTotalConnections = 200;
@Parameter(value = "elasticsearch_max_total_connections_per_route", validators = {PositiveIntegerValidator.class})
int elasticsearchMaxTotalConnectionsPerRoute = 20;
@Parameter(value = "elasticsearch_max_retries", validators = {PositiveIntegerValidator.class})
int elasticsearchMaxRetries = 2;
@Parameter(value = "elasticsearch_discovery_enabled")
boolean discoveryEnabled = false;
@Parameter(value = "elasticsearch_node_activity_logger_enabled")
boolean nodeActivityLogger = false;
@Parameter(value = "elasticsearch_discovery_filter")
String discoveryFilter = null;
@Parameter(value = "elasticsearch_discovery_frequency", validators = {PositiveDurationValidator.class})
Duration discoveryFrequency = Duration.seconds(30L);
@Parameter(value = "elasticsearch_discovery_default_scheme", validators = {HttpOrHttpsSchemeValidator.class})
String defaultSchemeForDiscoveredNodes = "http";
@Parameter(value = "elasticsearch_discovery_default_user")
String defaultUserForDiscoveredNodes = null;
@Parameter(value = "elasticsearch_discovery_default_password")
String defaultPasswordForDiscoveredNodes = null;
@Parameter(value = "elasticsearch_compression_enabled")
boolean compressionEnabled = false;
@Parameter(value = "elasticsearch_use_expect_continue")
boolean useExpectContinue = true;
@Parameter(value = "elasticsearch_mute_deprecation_warnings")
private boolean muteDeprecationWarnings = false;
@Parameter(value = "indexer_use_jwt_authentication")
boolean indexerUseJwtAuthentication = false;
@Parameter(value = "indexer_jwt_auth_token_caching_duration")
Duration indexerJwtAuthTokenCachingDuration = Duration.seconds(60);
@Parameter(value = "indexer_jwt_auth_token_expiration_duration")
Duration indexerJwtAuthTokenExpirationDuration = Duration.seconds(180);
@Parameter(value = "indexer_max_concurrent_searches")
Integer indexerMaxConcurrentSearches = null;
@Parameter(value = "indexer_max_concurrent_shard_requests")
Integer indexerMaxConcurrentShardRequests = null;
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy