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

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(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy