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

net.java.ao.RawEntity Maven / Gradle / Ivy

/*
 * Copyright 2007 Daniel Spiewak
 * 
 * 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.
 */
package net.java.ao;

import net.java.ao.schema.Ignore;

import java.beans.PropertyChangeEvent;
import java.beans.PropertyChangeListener;

/**
 * 

The superinterface for all entities, regardless of primary key. Developers * may choose to extend this interface rather than {@link Entity} if they * need to specify a custom primary key field. As this interface is the most * generic superinterface in the entity hierarchy, it defines most of the * common entity methods, such as {@link #save()} and * {@link #addPropertyChangeListener(PropertyChangeListener)}.

* *

This interface is parameterized for the sake of typechecking in the * {@link EntityManager#find(Class, String, Object...)} method. The generic * type specified when inheriting this interface should be the same as the * return type of the primary key method. Unfortunately, this is unenforcable, * so it is left up to the developers to ensure the spec is followed.

* * @author Daniel Spiewak */ public interface RawEntity { /** * Called when the entity instance is created. This method is defined * here in order to provide a common interface through an existing * mechanism. It is designed to be implemented within an entity * defined implementation. Any calls to this method will be ignored * by AO unless a defined implementation is present. */ @Ignore public void init(); /** * Saves all changed (dirty) fields within the entity to the database. This * method should almost never be overridden within a defined * implementation. However, it is possible to do so if absolutely * necessary. */ @Ignore public void save(); /** * Retrieves the {@link EntityManager} instance which manages this * entity. This method can be used by defined implementations to * get the relevant EntityManager instance in order * to run custom queries. * * @return The instance which manages this entity. */ @Ignore public EntityManager getEntityManager(); /** *

Returns the actual {@link Class} instance which corresponds to the * original entity interface. This is necessary because calling {@link Object#getClass()} * on a proxy instance doesn't return the value one would expect. As * such, RawEntity provides this method to give * developers access to the originating entity interface. Example:

* *
public interface Person extends Entity {
     *     // ...
     * }
     *
     * // ...
     * Person p = manager.get(Person.class, 2);
     * p.getEntityType();         // returns Person.class
     * p.getClass();           // indeterminate return value, probably something like $Proxy26.class
* * @return The {@link Class} which defines the entity in question. */ @Ignore public > Class getEntityType(); /** *

Adds a property change listener to the entity. This method is included * partly to emphasize compliance with the bean spec (sort of), but * more to enable developers to register listeners on the setters. This * method is called when the setter is called, not when {@link #save()} * is invoked.

* *

Be aware that the {@link PropertyChangeEvent} may or * may not have a valid oldValue. This is because * retrieving a previous value under many circumstances may result in an * extra database SELECT. If no oldValue is available in * memory, null will be passed.

* *

Any trivial custom code which only needs to run on mutator invocation * should use property change listeners, rather than a defined implementation.

* * @param listener The change listener to add. */ @Ignore public void addPropertyChangeListener(PropertyChangeListener listener); /** * Removes a property change listener from the entity. * * @param listener The change listener to remove. * @see #addPropertyChangeListener(PropertyChangeListener) */ @Ignore public void removePropertyChangeListener(PropertyChangeListener listener); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy