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

org.faktorips.runtime.IValidationContext Maven / Gradle / Ivy

Go to download

Runtime library for Faktor-IPS. When using the JAXB support use either faktorips-runtime-jakarta-xml or faktorips-runtime-javax-xml as dependency. When using CSV to read tables, add the optional dependencies to opencsv, commons-lang3 and commons-text. If you want to run Faktor-IPS tests as JUnit tests, you need to provide either junit (JUnit 4) or junit-jupiter-api (JUnit 5).

There is a newer version: 25.1.0.a20241030-01
Show newest version
/*******************************************************************************
 * Copyright (c) Faktor Zehn GmbH - faktorzehn.org
 * 
 * This source code is available under the terms of the AGPL Affero General Public License version
 * 3.
 * 
 * Please see LICENSE.txt for full license terms, including the additional permissions and
 * restrictions as well as the possibility of alternative license terms.
 *******************************************************************************/

package org.faktorips.runtime;

import java.util.Locale;

import org.faktorips.runtime.validation.DefaultGenericAttributeValidationConfiguration;
import org.faktorips.runtime.validation.IGenericAttributeValidationConfiguration;

/**
 * A validation context is provided to the validate() method generated by Faktor-IPS. By means of
 * the validation context the caller can provide additional information to the validate method like
 * for example the business context in which the validation is to execute.
 */
public interface IValidationContext {

    /**
     * Returns the Locale that is to use for the creation of validation messages.
     */
    Locale getLocale();

    /**
     * Returns the value for property with the specified name.
     */
    Object getValue(String propertyName);

    /**
     * Returns the configuration for generic attribute validation.
     *
     * @implSpec Implementers should overwrite this method to return their own implementation with
     *           custom error messages.
     * @implNote The default implementation always creates a new
     *           {@link DefaultGenericAttributeValidationConfiguration}.
     * @since 21.6
     */
    default IGenericAttributeValidationConfiguration getGenericAttributeValidationConfiguration() {
        return new DefaultGenericAttributeValidationConfiguration(getLocale());
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy