io.quarkiverse.opensearch.OpenSearchConfig Maven / Gradle / Ivy
package io.quarkiverse.opensearch;
import java.time.Duration;
import java.util.List;
import java.util.Optional;
import io.quarkus.runtime.annotations.ConfigPhase;
import io.quarkus.runtime.annotations.ConfigRoot;
import io.smallrye.config.ConfigMapping;
import io.smallrye.config.WithDefault;
import io.smallrye.config.WithName;
@ConfigMapping(prefix = "quarkus.opensearch")
@ConfigRoot(phase = ConfigPhase.RUN_TIME)
public interface OpenSearchConfig {
/**
* The list of hosts of the OpenSearch servers, when accessing AWS OpenSearch set to AWS endpoint name.
*
* Host Example: opensearch-01:9200,opensearch-02:9200
* AWS Endpoint Example: search-domain-name-identifier.region.es.amazonaws.com
*/
Optional> hosts();
/**
* The protocol to use when contacting OpenSearch servers.
* Set to "https" to enable SSL/TLS.
*/
@WithDefault("http")
String protocol();
/**
* The username for basic HTTP authentication.
*/
Optional username();
/**
* The password for basic HTTP authentication.
*/
Optional password();
/**
* The connection timeout.
*/
@WithDefault("15S")
Duration connectionTimeout();
/**
* The connection timeout.
*/
@WithDefault("30S")
Duration threadTimeout();
/**
* The socket timeout.
*/
@WithDefault("30S")
Duration socketTimeout();
/**
* The maximum number of connections to all the OpenSearch servers.
*/
@WithDefault("20")
int maxConnections();
/**
* The maximum number of connections per OpenSearch server.
*/
@WithDefault("10")
int maxConnectionsPerRoute();
/**
* The number of IO thread.
* By default, this is the number of locally detected processors.
*
* Thread counts higher than the number of processors should not be necessary because the I/O threads rely on non-blocking
* operations, but you may want to use a thread count lower than the number of processors.
*/
Optional ioThreadCounts();
/**
* AWS Region
*/
@WithName("aws.region")
@WithDefault("us-west-2")
String awsRegion();
/**
* Set to "es" or "aoss" to use AWS OpenSearch Service.
* es : Amazon OpenSearch Service
* aoss : Amazon OpenSearch Serverless
*/
@WithName("aws.service")
Optional awsService();
/**
* AWS Secret Access Key for setting up StaticCredentialsProvider
*/
@WithName("aws.access-key-id")
Optional accessKeyId();
/**
* AWS Secret Access Key Secret for setting up StaticCredentialsProvider
*/
@WithName("aws.access-key-secret")
Optional secretAccessKey();
/**
* Optional keyStoreFile to be used when connecting to cluster nodes
*/
@WithName("ssl.key-store-file")
Optional keyStoreFile();
/**
* Optional password for accessing keyStoreFile
*/
@WithName("ssl.key-store-password")
Optional keyStorePassword();
/**
* SSL Verify Hostname
*/
@WithName("ssl.verify-hostname")
@WithDefault("true")
boolean sslVerifyHostname();
/**
* Verify SSL Certificates
*/
@WithName("ssl.verify")
@WithDefault("true")
boolean sslVerify();
/**
* Configuration for the automatic discovery of new OpenSearch nodes.
*/
DiscoveryConfig discovery();
interface DiscoveryConfig {
/**
* Defines if automatic discovery is enabled.
*/
@WithDefault("false")
boolean enabled();
/**
* Refresh interval of the node list.
*/
@WithDefault("5M")
Duration refreshInterval();
}
}