/*
* Hibernate Validator, declare and validate application constraints
*
* License: Apache License, Version 2.0
* See the license.txt file in the root directory or <http://www.apache.org/licenses/LICENSE-2.0>.
*/
package org.hibernate.validator;
import java.time.Duration;
import java.util.Set;
import javax.validation.Configuration;
import javax.validation.TraversableResolver;
import javax.validation.constraints.Future;
import javax.validation.constraints.FutureOrPresent;
import javax.validation.constraints.Past;
import javax.validation.constraints.PastOrPresent;
import javax.validation.valueextraction.ValueExtractor;
import org.hibernate.validator.cfg.ConstraintMapping;
import org.hibernate.validator.constraints.ParameterScriptAssert;
import org.hibernate.validator.constraints.ScriptAssert;
import org.hibernate.validator.spi.resourceloading.ResourceBundleLocator;
import org.hibernate.validator.spi.scripting.ScriptEvaluator;
import org.hibernate.validator.spi.scripting.ScriptEvaluatorFactory;
Uniquely identifies Hibernate Validator in the Bean Validation bootstrap
strategy. Also contains Hibernate Validator specific configurations.
Author: Emmanuel Bernard, Gunnar Morling, Kevin Pollet <kevin.pollet@serli.com> (C) 2011 SERLI, Hardy Ferentschik, Chris Beckey <cbeckey@paypal.com>
/**
* Uniquely identifies Hibernate Validator in the Bean Validation bootstrap
* strategy. Also contains Hibernate Validator specific configurations.
*
* @author Emmanuel Bernard
* @author Gunnar Morling
* @author Kevin Pollet <kevin.pollet@serli.com> (C) 2011 SERLI
* @author Hardy Ferentschik
* @author Chris Beckey <cbeckey@paypal.com>
*/
public interface HibernateValidatorConfiguration extends Configuration<HibernateValidatorConfiguration> {
/**
* Property corresponding to the {@link #failFast} method.
* Accepts {@code true} or {@code false}. Defaults to {@code false}.
*/
String FAIL_FAST = "hibernate.validator.fail_fast";
Property corresponding to the allowOverridingMethodAlterParameterConstraint
method. Accepts true
or false
. Defaults to false
. /**
* Property corresponding to the {@link #allowOverridingMethodAlterParameterConstraint} method.
* Accepts {@code true} or {@code false}.
* Defaults to {@code false}.
*/
String ALLOW_PARAMETER_CONSTRAINT_OVERRIDE = "hibernate.validator.allow_parameter_constraint_override";
Property corresponding to the allowMultipleCascadedValidationOnReturnValues
method. Accepts true
or false
. Defaults to false
. /**
* Property corresponding to the {@link #allowMultipleCascadedValidationOnReturnValues} method.
* Accepts {@code true} or {@code false}.
* Defaults to {@code false}.
*/
String ALLOW_MULTIPLE_CASCADED_VALIDATION_ON_RESULT = "hibernate.validator.allow_multiple_cascaded_validation_on_result";
Property corresponding to the allowParallelMethodsDefineParameterConstraints
method. Accepts true
or false
. Defaults to false
. /**
* Property corresponding to the {@link #allowParallelMethodsDefineParameterConstraints} method.
* Accepts {@code true} or {@code false}.
* Defaults to {@code false}.
*/
String ALLOW_PARALLEL_METHODS_DEFINE_PARAMETER_CONSTRAINTS = "hibernate.validator.allow_parallel_method_parameter_constraint";
Deprecated: planned for removal. Use hibernate.validator.constraint_mapping_contributors instead. Since: 5.2
/**
* @deprecated planned for removal. Use hibernate.validator.constraint_mapping_contributors instead.
* @since 5.2
*/
@Deprecated
String CONSTRAINT_MAPPING_CONTRIBUTOR = "hibernate.validator.constraint_mapping_contributor";
Property for configuring constraint mapping contributors, allowing to set up one or more constraint mappings for the default validator factory. Accepts a String with the comma separated fully-qualified class names of one or more ConstraintMappingContributor
implementations. Since: 5.3
/**
* Property for configuring constraint mapping contributors, allowing to set up one or more constraint mappings for
* the default validator factory. Accepts a String with the comma separated fully-qualified class names of one or more
* {@link org.hibernate.validator.spi.cfg.ConstraintMappingContributor} implementations.
*
* @since 5.3
*/
String CONSTRAINT_MAPPING_CONTRIBUTORS = "hibernate.validator.constraint_mapping_contributors";
Property corresponding to the enableTraversableResolverResultCache(boolean)
. Accepts true
or false
. Defaults to true
. Since: 6.0.3
/**
* Property corresponding to the {@link #enableTraversableResolverResultCache(boolean)}.
* Accepts {@code true} or {@code false}.
* Defaults to {@code true}.
*
* @since 6.0.3
*/
String ENABLE_TRAVERSABLE_RESOLVER_RESULT_CACHE = "hibernate.validator.enable_traversable_resolver_result_cache";
Property for configuring the script evaluator factory, allowing to set up which factory will be used to create ScriptEvaluator
s for evaluation of script expressions in ScriptAssert
and ParameterScriptAssert
constraints. A fully qualified name of a class implementing ScriptEvaluatorFactory
is expected as a value. Since: 6.0.3
/**
* Property for configuring the script evaluator factory, allowing to set up which factory will be used to create
* {@link ScriptEvaluator}s for evaluation of script expressions in
* {@link ScriptAssert} and {@link ParameterScriptAssert}
* constraints. A fully qualified name of a class implementing {@link ScriptEvaluatorFactory} is expected as a value.
*
* @since 6.0.3
*/
@Incubating
String SCRIPT_EVALUATOR_FACTORY_CLASSNAME = "hibernate.validator.script_evaluator_factory";
Property for configuring temporal validation tolerance, allowing to set the acceptable margin of error when
comparing date/time in temporal constraints. In milliseconds.
Since: 6.0.5
/**
* Property for configuring temporal validation tolerance, allowing to set the acceptable margin of error when
* comparing date/time in temporal constraints. In milliseconds.
*
* @since 6.0.5
*/
@Incubating
String TEMPORAL_VALIDATION_TOLERANCE = "hibernate.validator.temporal_validation_tolerance";
Returns the ResourceBundleLocator
used by the default message
interpolator
to load user-provided resource bundles. In conformance with the specification this default locator retrieves the bundle "ValidationMessages".
This locator can be used as delegate for custom locators when setting a customized ResourceBundleMessageInterpolator
:
HibernateValidatorConfiguration configure =
Validation.byProvider(HibernateValidator.class).configure();
ResourceBundleLocator defaultResourceBundleLocator =
configure.getDefaultBundleLocator();
ResourceBundleLocator myResourceBundleLocator =
new MyResourceBundleLocator(defaultResourceBundleLocator);
configure.messageInterpolator(
new ResourceBundleMessageInterpolator(myResourceBundleLocator));
Returns: The default ResourceBundleLocator
. Never null.
/**
* <p>
* Returns the {@link ResourceBundleLocator} used by the
* {@link Configuration#getDefaultMessageInterpolator() default message
* interpolator} to load user-provided resource bundles. In conformance with
* the specification this default locator retrieves the bundle
* "ValidationMessages".
* </p>
* <p>
* This locator can be used as delegate for custom locators when setting a
* customized {@link org.hibernate.validator.messageinterpolation.ResourceBundleMessageInterpolator}:
* </p>
* <pre>
* {@code
* HibernateValidatorConfiguration configure =
* Validation.byProvider(HibernateValidator.class).configure();
*
* ResourceBundleLocator defaultResourceBundleLocator =
* configure.getDefaultBundleLocator();
* ResourceBundleLocator myResourceBundleLocator =
* new MyResourceBundleLocator(defaultResourceBundleLocator);
*
* configure.messageInterpolator(
* new ResourceBundleMessageInterpolator(myResourceBundleLocator));
* }
* </pre>
*
* @return The default {@link ResourceBundleLocator}. Never null.
*/
ResourceBundleLocator getDefaultResourceBundleLocator();
Creates a new constraint mapping which can be used to programmatically configure the constraints for given types. After the mapping has been set up, it must be added to this configuration via addMapping(ConstraintMapping)
. Returns: A new constraint mapping.
/**
* Creates a new constraint mapping which can be used to programmatically configure the constraints for given types. After
* the mapping has been set up, it must be added to this configuration via {@link #addMapping(ConstraintMapping)}.
*
* @return A new constraint mapping.
*/
ConstraintMapping createConstraintMapping();
Returns the default ValueExtractor
implementations as per the specification. Returns: the default ValueExtractor
implementations compliant with the specification Since: 6.0
/**
* Returns the default {@link ValueExtractor} implementations as per the
* specification.
*
* @return the default {@code ValueExtractor} implementations compliant
* with the specification
*
* @since 6.0
*/
@Incubating
Set<ValueExtractor<?>> getDefaultValueExtractors();
Adds the specified ConstraintMapping
instance to the configuration. Constraints configured in mapping
will be added to the constraints configured via annotations and/or xml. Params: - mapping –
ConstraintMapping
instance containing programmatic configured constraints
Throws: - IllegalArgumentException – if
mapping
is null
Returns: this
following the chaining method pattern
/**
* Adds the specified {@link ConstraintMapping} instance to the configuration. Constraints configured in {@code mapping}
* will be added to the constraints configured via annotations and/or xml.
*
* @param mapping {@code ConstraintMapping} instance containing programmatic configured constraints
*
* @return {@code this} following the chaining method pattern
*
* @throws IllegalArgumentException if {@code mapping} is {@code null}
*/
HibernateValidatorConfiguration addMapping(ConstraintMapping mapping);
En- or disables the fail fast mode. When fail fast is enabled the validation
will stop on the first constraint violation detected.
Params: - failFast –
true
to enable fail fast, false
otherwise.
Returns: this
following the chaining method pattern
/**
* En- or disables the fail fast mode. When fail fast is enabled the validation
* will stop on the first constraint violation detected.
*
* @param failFast {@code true} to enable fail fast, {@code false} otherwise.
*
* @return {@code this} following the chaining method pattern
*/
HibernateValidatorConfiguration failFast(boolean failFast);
Sets the class loader to be used for loading user-provided resources:
- XML descriptors (
META-INF/validation.xml
as well as XML constraint mappings)
- classes specified by name in XML descriptors (e.g. custom message interpolators etc.)
- the
ValidationMessages
resource bundle
If no class loader is given, these resources will be obtained through the thread context class loader and as a
last fallback through Hibernate Validator's own class loader.
Params: - externalClassLoader – The class loader for loading user-provided resources.
Returns: this
following the chaining method patternSince: 5.2
/**
* Sets the class loader to be used for loading user-provided resources:
* <ul>
* <li>XML descriptors ({@code META-INF/validation.xml} as well as XML constraint mappings)</li>
* <li>classes specified by name in XML descriptors (e.g. custom message interpolators etc.)</li>
* <li>the {@code ValidationMessages} resource bundle</li>
* </ul>
* If no class loader is given, these resources will be obtained through the thread context class loader and as a
* last fallback through Hibernate Validator's own class loader.
*
* @param externalClassLoader The class loader for loading user-provided resources.
*
* @return {@code this} following the chaining method pattern
*
* @since 5.2
*/
HibernateValidatorConfiguration externalClassLoader(ClassLoader externalClassLoader);
Define whether overriding methods that override constraints should throw a ConstraintDefinitionException
. The default value is false
, i.e. do not allow.
See Section 4.5.5 of the JSR 380 specification, specifically
"In sub types (be it sub classes/interfaces or interface implementations), no parameter constraints may
be declared on overridden or implemented methods, nor may parameters be marked for cascaded validation.
This would pose a strengthening of preconditions to be fulfilled by the caller."
Params: - allow – flag determining whether validation will allow overriding to alter parameter constraints.
Returns: this
following the chaining method patternSince: 5.3
/**
* Define whether overriding methods that override constraints should throw a {@code ConstraintDefinitionException}.
* The default value is {@code false}, i.e. do not allow.
* <p>
* See Section 4.5.5 of the JSR 380 specification, specifically
* <pre>
* "In sub types (be it sub classes/interfaces or interface implementations), no parameter constraints may
* be declared on overridden or implemented methods, nor may parameters be marked for cascaded validation.
* This would pose a strengthening of preconditions to be fulfilled by the caller."
* </pre>
*
* @param allow flag determining whether validation will allow overriding to alter parameter constraints.
*
* @return {@code this} following the chaining method pattern
*
* @since 5.3
*/
HibernateValidatorConfiguration allowOverridingMethodAlterParameterConstraint(boolean allow);
Define whether more than one constraint on a return value may be marked for cascading validation are allowed. The default value is false
, i.e. do not allow.
See Section 4.5.5 of the JSR 380 specification, specifically
"One must not mark a method return value for cascaded validation more than once in a line of a class hierarchy.
In other words, overriding methods on sub types (be it sub classes/interfaces or interface implementations)
cannot mark the return value for cascaded validation if the return value has already been marked on the
overridden method of the super type or interface."
Params: - allow – flag determining whether validation will allow multiple cascaded validation on return values.
Returns: this
following the chaining method patternSince: 5.3
/**
* Define whether more than one constraint on a return value may be marked for cascading validation are allowed.
* The default value is {@code false}, i.e. do not allow.
* <p>
* See Section 4.5.5 of the JSR 380 specification, specifically
* <pre>
* "One must not mark a method return value for cascaded validation more than once in a line of a class hierarchy.
* In other words, overriding methods on sub types (be it sub classes/interfaces or interface implementations)
* cannot mark the return value for cascaded validation if the return value has already been marked on the
* overridden method of the super type or interface."
* </pre>
*
* @param allow flag determining whether validation will allow multiple cascaded validation on return values.
*
* @return {@code this} following the chaining method pattern
*
* @since 5.3
*/
HibernateValidatorConfiguration allowMultipleCascadedValidationOnReturnValues(boolean allow);
Define whether parallel methods that define constraints should throw a ConstraintDefinitionException
. The default value is false
, i.e. do not allow.
See Section 4.5.5 of the JSR 380 specification, specifically
"If a sub type overrides/implements a method originally defined in several parallel types of the hierarchy
(e.g. two interfaces not extending each other, or a class and an interface not implemented by said class),
no parameter constraints may be declared for that method at all nor parameters be marked for cascaded validation.
This again is to avoid an unexpected strengthening of preconditions to be fulfilled by the caller."
Params: - allow – flag determining whether validation will allow parameter constraints in parallel hierarchies
Returns: this
following the chaining method patternSince: 5.3
/**
* Define whether parallel methods that define constraints should throw a {@code ConstraintDefinitionException}. The
* default value is {@code false}, i.e. do not allow.
* <p>
* See Section 4.5.5 of the JSR 380 specification, specifically
* <pre>
* "If a sub type overrides/implements a method originally defined in several parallel types of the hierarchy
* (e.g. two interfaces not extending each other, or a class and an interface not implemented by said class),
* no parameter constraints may be declared for that method at all nor parameters be marked for cascaded validation.
* This again is to avoid an unexpected strengthening of preconditions to be fulfilled by the caller."
* </pre>
*
* @param allow flag determining whether validation will allow parameter constraints in parallel hierarchies
*
* @return {@code this} following the chaining method pattern
*
* @since 5.3
*/
HibernateValidatorConfiguration allowParallelMethodsDefineParameterConstraints(boolean allow);
Define whether the per validation call caching of TraversableResolver
results is enabled. The default value is true
, i.e. the caching is enabled. This behavior was initially introduced to cache the JPATraversableResolver
results but the map lookups it introduces can be counterproductive when the TraversableResolver
calls are very fast.
Params: - enabled – flag determining whether per validation call caching is enabled for
TraversableResolver
results.
Returns: this
following the chaining method patternSince: 6.0.3
/**
* Define whether the per validation call caching of {@link TraversableResolver} results is enabled. The default
* value is {@code true}, i.e. the caching is enabled.
* <p>
* This behavior was initially introduced to cache the {@code JPATraversableResolver} results but the map lookups it
* introduces can be counterproductive when the {@code TraversableResolver} calls are very fast.
*
* @param enabled flag determining whether per validation call caching is enabled for {@code TraversableResolver}
* results.
*
* @return {@code this} following the chaining method pattern
*
* @since 6.0.3
*/
HibernateValidatorConfiguration enableTraversableResolverResultCache(boolean enabled);
Allows to specify a custom ScriptEvaluatorFactory
responsible for creating ScriptEvaluator
s used to evaluate script expressions for ScriptAssert
and ParameterScriptAssert
constraints. Params: - scriptEvaluatorFactory – the
ScriptEvaluatorFactory
to be used
Returns: this
following the chaining method patternSince: 6.0.3
/**
* Allows to specify a custom {@link ScriptEvaluatorFactory} responsible for creating {@link ScriptEvaluator}s
* used to evaluate script expressions for {@link ScriptAssert} and {@link ParameterScriptAssert} constraints.
*
* @param scriptEvaluatorFactory the {@link ScriptEvaluatorFactory} to be used
*
* @return {@code this} following the chaining method pattern
*
* @since 6.0.3
*/
@Incubating
HibernateValidatorConfiguration scriptEvaluatorFactory(ScriptEvaluatorFactory scriptEvaluatorFactory);
Allows to set the acceptable margin of error when comparing date/time in temporal constraints such as Past
/PastOrPresent
and Future
/FutureOrPresent
. Params: - temporalValidationTolerance – the acceptable tolerance
Returns: this
following the chaining method patternSince: 6.0.5
/**
* Allows to set the acceptable margin of error when comparing date/time in temporal constraints such as
* {@link Past}/{@link PastOrPresent} and {@link Future}/{@link FutureOrPresent}.
*
* @param temporalValidationTolerance the acceptable tolerance
*
* @return {@code this} following the chaining method pattern
*
* @since 6.0.5
*/
@Incubating
HibernateValidatorConfiguration temporalValidationTolerance(Duration temporalValidationTolerance);
Allows to set a payload which will be passed to the constraint validators. If the method is called multiple
times, only the payload passed last will be propagated.
Params: - constraintValidatorPayload – the payload passed to constraint validators
Returns: this
following the chaining method patternSince: 6.0.8
/**
* Allows to set a payload which will be passed to the constraint validators. If the method is called multiple
* times, only the payload passed last will be propagated.
*
* @param constraintValidatorPayload the payload passed to constraint validators
*
* @return {@code this} following the chaining method pattern
*
* @since 6.0.8
*/
@Incubating
HibernateValidatorConfiguration constraintValidatorPayload(Object constraintValidatorPayload);
}