Uploaded image for project: 'Bean Validation'
  1. BVAL-214

Ability to validate an object and a list of changes


    • Last commented by a user?:
    • Sprint:


      Pass a list of changes applied to an object graph and validate the object graph had the change been applied.
      This is useful for presentation layers like JSF for cross field validations for example.

      There are several possibilities to implement that:

      1. pass in a Map<String,Object> with the list of changed properties

      validator.validateObject(Object model,Map<String,Object> newValues, Class ...profile)

      2. pass in a set of more typesafe changedset but essentially the same as 1.

      changeSet.change("property", value).change("property2", null).remove("collection", index);
      validator.validateObject(Object model,ChangeSet changeSet, Class ...profile)

      3. pass a proxy of the object and apply changes to the proxy. One of the benefits of this approach is that it is transparent to the validator API. The drawback is that the object must be proxyable

      User proxiedUser = proxyfier.proxy(user);
      validator.validateObject(Object proxiedUser, Class ...profile)

      More info from Alex

      Client side validation already implemented in coming RichFaces 4.0 release, that's not a subject for bean validation. From the JSF side, the cool feature would be object validation that doesn't touch model itself. Currently, we can only validate a single bean attribute aganist new value, that doesn't allow. In richfaces, I do make a 'clone' of target object, update it with new values and perform validation on the cloned object. Would be nice to have something like: validator.validateObject(Object model,Map<String,Object> newValues, Class ...profile) that does a similar work.


          Issue links



              • Votes:
                6 Vote for this issue
                11 Start watching this issue


                • Created: