/*
* Copyright 2017-2020 original authors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* https://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.micronaut.validation.validator;
import io.micronaut.core.beans.BeanIntrospection;
import edu.umd.cs.findbugs.annotations.NonNull;
import edu.umd.cs.findbugs.annotations.Nullable;
import javax.validation.Constraint;
import javax.validation.ConstraintViolation;
import javax.validation.Valid;
import java.util.Set;
Extended version of the Valid
interface for Micronaut's implementation. The Validator.getConstraintsForClass(Class<?>)
method is not supported by the implementation.
Author: graemerocher Since: 1.2
/**
* Extended version of the {@link javax.validation.Valid} interface for Micronaut's implementation.
*
* <p>The {@link #getConstraintsForClass(Class)} method is not supported by the implementation.</p>
*
* @author graemerocher
* @since 1.2
*/
public interface Validator extends javax.validation.Validator {
Annotation used to define an object as valid.
/**
* Annotation used to define an object as valid.
*/
String ANN_VALID = Valid.class.getName();
Annotation used to define a constraint.
/**
* Annotation used to define a constraint.
*/
String ANN_CONSTRAINT = Constraint.class.getName();
Overridden variation that returns a ExecutableMethodValidator
. Returns: The validator
/**
* Overridden variation that returns a {@link ExecutableMethodValidator}.
* @return The validator
*/
@Override
@NonNull ExecutableMethodValidator forExecutables();
@Override
@NonNull <T> Set<ConstraintViolation<T>> validate(
@NonNull T object,
Class<?>... groups
);
Validate the given introspection and object.
Params: - introspection – The introspection
- object – The object
- groups – The groups
Type parameters: - <T> – The object type
Returns: The constraint violations
/**
* Validate the given introspection and object.
* @param introspection The introspection
* @param object The object
* @param groups The groups
* @param <T> The object type
* @return The constraint violations
*/
@NonNull
<T> Set<ConstraintViolation<T>> validate(
@NonNull BeanIntrospection<T> introspection,
@NonNull T object, @Nullable Class<?>... groups);
@Override
@NonNull <T> Set<ConstraintViolation<T>> validateProperty(
@NonNull T object,
@NonNull String propertyName,
Class<?>... groups
);
@Override
@NonNull <T> Set<ConstraintViolation<T>> validateValue(
@NonNull Class<T> beanType,
@NonNull String propertyName,
@Nullable Object value,
Class<?>... groups
);
Constructs a new default instance. Note that the returned instance will not contain managed ConstraintValidator
instances and using Inject
should be preferred. Returns: The validator.
/**
* Constructs a new default instance. Note that the returned instance will not contain
* managed {@link io.micronaut.validation.validator.constraints.ConstraintValidator} instances and using
* {@link javax.inject.Inject} should be preferred.
*
* @return The validator.
*/
static @NonNull Validator getInstance() {
return new DefaultValidator(
new DefaultValidatorConfiguration()
);
}
}