io.permazen.ValidationMode Maven / Gradle / Ivy
Show all versions of permazen-main Show documentation
/*
* Copyright (C) 2015 Archie L. Cobbs. All rights reserved.
*/
package io.permazen;
/**
* Configures whether and how objects are enqueued for validation in a {@link JTransaction}.
*
* @see io.permazen.JTransaction#validate
* @see io.permazen.JObject#revalidate
* @see io.permazen.annotation.OnValidate
*/
public enum ValidationMode {
/**
* Validation is disabled. No objects are enqueued for validation, even if {@link JObject#revalidate} is invoked.
*/
DISABLED,
/**
* Objects are enqueued for validation only when {@link JObject#revalidate} is explicitly invoked.
*/
MANUAL,
/**
* Objects are enqueued for validation automatically (if necessary) when they are modified.
*
*
* In this mode, objects are enqueued for validation whenever {@link JObject#revalidate} is invoked; in addition,
* objects are enqueued for validation automatically as if by {@link JObject#revalidate} when:
*
* - An instance is {@linkplain io.permazen.JTransaction#create created}, and the Java model type (or any super-type)
* has a JSR 303 annotated public method or {@link io.permazen.annotation.OnValidate @OnValidate} annoted method
* - An instance is {@linkplain io.permazen.JObject#upgrade upgraded}, and the Java model type (or any super-type)
* has a JSR 303 annotated public method or {@link io.permazen.annotation.OnValidate @OnValidate} annoted method
* - An instance field is modified, and the corresponding Java model `getter' method has any JSR 303 annotations
*
*
*
* Note that the presence of a {@link io.permazen.annotation.OnValidate @OnValidate} annotation on a method
* does not in itself result in automatic validation when any field changes (it merely specifies an action
* to take when validation occurs). To trigger revalidation after field changes, add
* {@link io.permazen.annotation.OnChange @OnChange}-annotated method(s) that invoke
* {@link io.permazen.JObject#revalidate this.revalidate()}.
*
*
* Note that {@link #AUTOMATIC} enqueues as if by {@link JObject#revalidate}, i.e., the
* {@link javax.validation.groups.Default} validation group applies. Therefore, if a constraint has explicit {@code groups()},
* and none extend {@link javax.validation.groups.Default}, then it will not be applied automatically.
*/
AUTOMATIC;
}