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

org.apache.openjpa.persistence.validation.TraversableResolverImpl Maven / Gradle / Ivy

There is a newer version: 4.0.1
Show newest version
/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements. See the NOTICE file distributed with this
 * work for additional information regarding copyright ownership. The ASF
 * licenses this file to you 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
 *
 * http://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 org.apache.openjpa.persistence.validation;

import java.lang.annotation.ElementType;

import jakarta.persistence.spi.LoadState;
import jakarta.validation.Path;
import jakarta.validation.Path.Node;
import jakarta.validation.TraversableResolver;

import org.apache.openjpa.persistence.OpenJPAPersistenceUtil;

/**
 * OpenJPA optimized TraversableResolver Default implementation/behavior asks all discovered providers -
 * jakarta.persistence.Persistence.getPersistenceUtil().isLoaded( traversableObject, traversableProperty.getName());
 *
 * @see jakarta.validation.TraversableResolver
 */
public class TraversableResolverImpl implements TraversableResolver {

    public TraversableResolverImpl() {
    }

    /* (non-Javadoc) isReachable() is called by the Validator before accessing
     * a property for validation or for cascading.
     *
     * @see jakarta.validation.TraversableResolver#isReachable(java.lang.Object,
     *      jakarta.validation.Path.Node, java.lang.Class, jakarta.validation.Path,
     *      java.lang.annotation.ElementType)
     */
    @Override
    public boolean isReachable(Object traversableObject,
        Node traversableProperty, Class rootBeanType,
        Path pathToTraversableObject, ElementType elementType) {

        /*
         * OpenJPA optimized version of the default provider implementation,
         * which doesn't ask all the providers on the classpath about the obj.
         */
        if (OpenJPAPersistenceUtil.isLoaded(traversableObject, traversableProperty.getName()) == LoadState.NOT_LOADED) {
            return false;
        } else {
            // LoadState.LOADED or LoadState.UNKNOWN
            return true;
        }
    }

    /* (non-Javadoc) isCascadable() is called by the Validator after
     * isReachable() returns true and before a property marked with @Valid
     * is cascaded.
     *
     * @see jakarta.validation.TraversableResolver#isCascadable(java.lang.Object,
     *      jakarta.validation.Path.Node, java.lang.Class, jakarta.validation.Path,
     *      java.lang.annotation.ElementType)
     */
    @Override
    public boolean isCascadable(Object traversableObject,
        Node traversableProperty, Class rootBeanType,
        Path pathToTraversableObject, ElementType elementType) {

        // BV Spec Section 3.5.2 says to always return true for JPA ???
        return true;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy