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

org.efaps.importer.AbstractObject Maven / Gradle / Ivy

/*
 * Copyright 2003 - 2012 The eFaps Team
 *
 * 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.
 *
 * Revision:        $Rev: 7483 $
 * Last Changed:    $Date: 2012-05-11 11:57:38 -0500 (Fri, 11 May 2012) $
 * Last Changed By: $Author: [email protected] $
 */

package org.efaps.importer;

import java.util.Map;
import java.util.Set;

/**
 * Abstract Class for Importing Objects into the Database connected to eFaps.
 *
 * @author The eFaps Team
 * @version $Id: AbstractObject.java 7483 2012-05-11 16:57:38Z [email protected] $
 */
public abstract class AbstractObject
{
    /**
     * Returns the links of the object.
     *
     * @return Set with the ForeignObjects connected to this Object
     */
    public abstract Set getLinks();

    /**
     * Returns the type of the object.
     *
     * @return type of the object
     */
    public abstract String getType();

    /**
     * Returns the value of an attribute.
     *
     * @param _attribute    attribute of the searched value
     * @return object with the Value, null if the attribute does
     *         not exist
     */
    public abstract Object getAttribute(final String _attribute);

    /**
     * Returns the map with all attributes.
     *
     * @return map containing all Attributes
     */
    public abstract Map getAttributes();

    /**
     * Returns the id of the object.
     *
     * @return string with the id of the object
     */
    public abstract long getID();

    /**
     * Sets the id of the object.
     *
     * @param _id   new id of the object
     */
    public abstract void setID(final long _id);

    /**
     * Returns the attribute which contains the parent-child relationship.
     *
     * @return String with the Name of the Attribute
     */
    public abstract String getParrentAttribute();

    /**
     * Has the object a checkin object?
     *
     * @return true if so, otherwise false
     */
    public abstract boolean isCheckinObject();

    /**
     * Returns the unique attributes.
     *
     * @return set of the unique attributes
     */
    public abstract Set getUniqueAttributes();

    /**
     * Has the Object children?
     *
     * @return true if the Object has children, otherwise false
     */
    public abstract boolean hasChilds();

    /**
     * File is checked into the object.
     */
    public abstract void dbCheckObjectIn();

    /**
     * Appends in eFaps all children.
     */
    public abstract void dbAddChilds();

    /**
     * Create or update of the object in eFaps.
     *
     * @param _parent   Parent-Object of this Object
     * @param _id       id of the Object to be updated, if an empty string is
     *                  given an insert will be made
     * @return string with the id of the new or updated object
     */
    public abstract long dbUpdateOrInsert(final AbstractObject _parent,
                                          final long _id);
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy