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

io.permazen.ValidationMode Maven / Gradle / Ivy

There is a newer version: 5.1.0
Show newest version

/*
 * 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; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy