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

org.hibernate.search.engine.cfg.spi.ConfigurationProvider Maven / Gradle / Ivy

There is a newer version: 8.0.0.Alpha1
Show newest version
/*
 * SPDX-License-Identifier: Apache-2.0
 * Copyright Red Hat Inc. and Hibernate Authors
 */
package org.hibernate.search.engine.cfg.spi;

import java.util.Optional;

import org.hibernate.search.engine.cfg.ConfigurationPropertySource;
import org.hibernate.search.engine.environment.bean.spi.BeanConfigurer;
import org.hibernate.search.util.common.annotation.Incubating;

/**
 * Allows integrators to provide their default configuration properties for various scopes that would override
 * Hibernate Search specific ones.
 */
@Incubating
public interface ConfigurationProvider {

	/**
	 * Provide a configuration property source for the given scope.
	 * 

* Property sources created by this provider must follow these rules: *

    *
  • * A property source only contains properties that are relevant for the given scope. * E.g. a global scope property source should not contain any configuration properties * for a specific index with the {@code backend.indexes.myindex} prefix; * if such a property is defined in a global scope source and then overridden in a backend/index scope * (without the prefix), * the value will be taken from the global source and backend/index ones will be silently ignored. *
  • *
  • * Property keys must be relative to the scope. * No keys should start with {@code hibernate.search.} prefix. * Assuming we want to redefine a property {@code hibernate.search.backend.directory.type} in the backend scope, * then Hibernate Search would expect that the property source returned by this provider for a backend scope * will contain a value for a {@code directory.type} key. *
  • *
  • * For global-scope property sources, * the {@link EngineSpiSettings#BEAN_CONFIGURERS bean_configurers} configuration property * is only ever looked up if this provider was registered by * a {@link BeanConfigurer} added through the Java {@link java.util.ServiceLoader} system. * A provider registered by a {@link BeanConfigurer} added through * the {@link EngineSpiSettings#BEAN_CONFIGURERS bean_configurers} configuration property * cannot itself set the {@link EngineSpiSettings#BEAN_CONFIGURERS bean_configurers} configuration property. *
  • *
* * @param scope The scope for which configuration properties are about to be used. * @return An empty optional if the provider does not need to override any Hibernate Search specific defaults * for a provided {@code scope}, or a {@link ConfigurationPropertySource} with overrides otherwise. */ Optional get(ConfigurationScope scope); /** * Defines a priority of a particular configuration provider. *

* If multiple configuration providers are available they will be sorted by their {@link #priority() priority} * and then by FQCN to guarantee a predictable order. * * @return The priority of the current provider. */ default int priority() { return 0; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy