/* * #%L * BroadleafCommerce Open Admin Platform * %% * Copyright (C) 2009 - 2013 Broadleaf Commerce * %% * Licensed 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. * #L% */ package org.broadleafcommerce.openadmin.server.service.persistence.validation; import org.broadleafcommerce.common.presentation.ValidationConfiguration; import org.broadleafcommerce.openadmin.dto.BasicFieldMetadata; import org.broadleafcommerce.openadmin.dto.Entity; import org.broadleafcommerce.openadmin.dto.FieldMetadata; import org.broadleafcommerce.openadmin.server.service.persistence.module.BasicPersistenceModule; import java.io.Serializable; import java.util.Map; /** * Analagous to {@link PropertyValidator} except this does not attempt to use any {@link ValidationConfiguration} from an * {@link AdminPresentation} annotation. These global validators will execute on every field of every entity that is * attempted to be populated by the admin * * @author Phillip Verheyden (phillipuniverse) * @see {@link PropertyValidator} * @see {@link EntityValidatorService#getGlobalEntityValidators()} * @see {@link BasicPersistenceModule#createPopulatedInstance(Serializable, Entity, Map, Boolean)} */ public interface GlobalPropertyValidator { /** * Validates a property for an entity * * @param entity Entity DTO of the entity attempting to save * @param instance actual object representation of <b>entity</b>. This can be cast to entity interfaces (like Sku or * Product) * @param entityFieldMetadata complete field metadata for all properties in <b>entity</b> * @param propertyMetadata {@link BasicFieldMetadata} corresponding to the property that is being valid * @param propertyName the property name of the value attempting to be saved (could be a sub-entity obtained via dot * notation like 'defaultSku.name') * @param value the value attempted to be saved * @return <b>true</b> if this passes validation, <b>false</b> otherwise. */ public PropertyValidationResult validate(Entity entity, Serializable instance, Map<String, FieldMetadata> entityFieldMetadata, BasicFieldMetadata propertyMetadata, String propertyName, String value); }