@Target(value=METHOD) @Retention(value=RUNTIME) public @interface ConditionalVisitorFieldValidator
The validator allows you to forward validator to object properties of your action using the objects own validator files. This allows you to use the ModelDriven development pattern and manage your validations for your models in one place, where they belong, next to your model classes.
The ConditionalVisitorFieldValidator can handle either simple Object properties, Collections of Objects, or Arrays. The error message for the ConditionalVisitorFieldValidator will be appended in front of validator messages added by the validations for the Object message.
Annotation usage:
The annotation must be applied at method level.
Annotation parameters:
| Parameter | Required | Default | Notes | 
|---|---|---|---|
| expression | yes | Boolean conditional expression | |
| message | yes | field error message | |
| key | no | i18n key from language specific properties file. | |
| messageParams | no | Additional params to be used to customize message - will be evaluated against the Value Stack | |
| fieldName | no | ||
| shortCircuit | no | false | If this validator should be used as shortCircuit. | 
| context | no | action alias | Determines the context to use for validating the Object property. If not defined, the context of the Action validation is propagated to the Object property validation. In the case of Action validation, this context is the Action alias. | 
| appendPrefix | no | true | Determines whether the field name of this field validator should be prepended to the field name of the visited field to determine the full field name when an error occurs.  For example, suppose that the bean being validated has a "name" property.  If appendPrefix is true, then the field error will be stored under the field "bean.name".  If appendPrefix is false, then the field error will be stored under the field "name".  If you are using the VisitorFieldValidator to validate the model from a ModelDriven Action, you should set appendPrefix to false unless you are using "model.name" to reference the properties on your model. | 
Example code:
@ConditionalVisitorFieldValidator(expression="app.appid > 100", message = "Default message", key = "i18n.key", shortCircuit = true, context = "action alias", appendPrefix = true)
| Modifier and Type | Required Element and Description | 
|---|---|
| String | expression | 
| Modifier and Type | Optional Element and Description | 
|---|---|
| boolean | appendPrefixDetermines whether the field name of this field validator should be prepended to the field name of
 the visited field to determine the full field name when an error occurs. | 
| String | contextDetermines the context to use for validating the Object property. | 
| String | fieldName | 
| String | key | 
| String | message | 
| String[] | messageParams | 
| boolean | shortCircuitIf this is activated, the validator will be used as short-circuit. | 
public abstract String expression
public abstract String context
public abstract boolean appendPrefix
public abstract String message
public abstract String key
public abstract String[] messageParams
public abstract String fieldName
Copyright © 2000–2023 Apache Software Foundation. All rights reserved.