Skip to content
EntityProperty.java 4.61 KiB
Newer Older
/* 
 * _____________________________________________________________________________
 * 
 * INAF - OATS National Institute for Astrophysics - Astronomical Observatory of
 * Trieste INAF - IA2 Italian Center for Astronomical Archives
 * _____________________________________________________________________________
 * 
 * Copyright (C) 2016 Istituto Nazionale di Astrofisica
 * 
 * This program is free software; you can redistribute it and/or modify it under
 * the terms of the GNU General Public License Version 3 as published by the
 * Free Software Foundation.
 * 
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
 * details.
 * 
 * You should have received a copy of the GNU General Public License along with
 * this program; if not, write to the Free Software Foundation, Inc., 51
 * Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 */
package it.inaf.ia2.tsm;
import it.inaf.ia2.tsm.model.ColumnModel;
 * Store the value of an entity property (that corresponds to a column of the
 * mapped table).
 *
 * @author Sonia Zorba {@literal <zorba at oats.inaf.it>}
 */
public class EntityProperty<T> implements Serializable {
    private static final long serialVersionUID = 6735553751078589085L;
    private ColumnModel propertyModel;
    private T originalValue;
    private T value;
    private boolean changed;
    private EntityProperty() {
    public EntityProperty(ColumnModel propertyModel, T defaultValue) {
        this.propertyModel = propertyModel;
        this.type = propertyModel.getJavaType();
     * Returns the current value of this property (the last value set).
     */
    public T getValue() {
        return value;
    }

    /**
     * Returns the initial value of this property.
     */
    public T getOriginalValue() {
        return originalValue;
    }

    /**
     * Returns the default value for this property, as defined into the
     * {@code ColumnModel} parsed from the XML configuration.
     */
    public T getDefaultValue() {
        return defaultValue;
    }

    /**
     * Sets the current value for this property.
     */
        this.setValue(value, true);
    }

    private <X> void setValue(X value, boolean checkUpdatable) {
        assert value == null || value.getClass() == type;
        if (checkUpdatable && !propertyModel.isUpdatable()) {
            throw new UnsupportedOperationException("This EntityProperty instance (" + propertyModel.getName() + ") is not updatable");
        }
        if (value == null && !propertyModel.isNullable()) {
            throw new IllegalArgumentException("This EntityProperty instance (" + propertyModel.getName() + ") doesn't allow null values");
    /**
     * Returns true if the current value is different from the initial value.
     */
        if (originalValue == null) {
            return value != null;
        }
        return !originalValue.equals(value);
    }

     * Initializes the value of the property.
     *
     * @param <X> a class compatible con the {@code ColumnModel} definition used
     * by this property.
     * @param initialValue the initial value for this property.
    public final <X> void init(X initialValue) {
        if (!propertyModel.isNullable() && initialValue == null) {
            initialValue = (X) propertyModel.getDefaultValue();
        }
        setValue(initialValue, false);
    /**
     * Sets the current value as the initial value.
     */
    public void save() {
        this.originalValue = value;
    }
    /**
     * Returns the class of the property value.
     */
    public Class getType() {
        return type;
    }
    /**
     * Indicates if the property value can be edited by the user.
     *
     * @return true if the property value can be edited by the user, false
     * otherwise
     */
    public boolean isUpdatable() {
        return propertyModel.isUpdatable();
    }

    /**
     * Indicates if the property can have a null value.
     *
     * @return true if the property can have a null value, false otherwise.
     */
    public boolean isNullable() {
        return propertyModel.isNullable();
    }