/** * Redistribution and use of this software and associated documentation * ("Software"), with or without modification, are permitted provided * that the following conditions are met: * * 1. Redistributions of source code must retain copyright * statements and notices. Redistributions must also contain a * copy of this document. * * 2. Redistributions in binary form must reproduce the * above copyright notice, this list of conditions and the * following disclaimer in the documentation and/or other * materials provided with the distribution. * * 3. The name "Exolab" must not be used to endorse or promote * products derived from this Software without prior written * permission of Intalio, Inc. For written permission, * please contact info@exolab.org. * * 4. Products derived from this Software may not be called "Exolab" * nor may "Exolab" appear in their names without prior written * permission of Intalio, Inc. Exolab is a registered * trademark of Intalio, Inc. * * 5. Due credit should be given to the Exolab Project * (http://www.exolab.org/). * * THIS SOFTWARE IS PROVIDED BY INTALIO, INC. AND CONTRIBUTORS * ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT * NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND * FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL * INTALIO, INC. OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED * OF THE POSSIBILITY OF SUCH DAMAGE. * * Copyright 1999 (C) Intalio, Inc. All Rights Reserved. * * $Id$ */ package org.exolab.castor.persist.spi; import org.castor.persist.ProposedEntity; import org.exolab.castor.jdo.Database; import org.exolab.castor.jdo.PersistenceException; import org.exolab.castor.jdo.QueryException; import org.exolab.castor.mapping.AccessMode; import org.exolab.castor.mapping.TypeConvertor; import org.exolab.castor.persist.SQLRelationLoader; /** * The persistence engine implements this interface in order to allow * objects to be created, removed, loaded, stored, locked and checked * for dirtyness. * <p> * The caller takes full responsibility to assure integrity of * transactions and object caching and only relies on the engine to * assist in assuring that through the mechanisms available to it. * <p> * All method calls provide an open connection into the persistence * storage. The connection is opened by and maintained in the context * of a transaction. The type of the connection depends on the * persistence engine (JDBC, JNDI, etc). * <p> * All method calls provide the object fields and the object identity. * The engine must always use the identity passed in the method call * and never the identity contained in the object itself. * <p> * The stamp is an arbitrary object that is returned on object * creation and loading and passed when performing a dirty check. The * stamp can be used to detect object dirtyness in a more efficient * manner in database that support a stamping mechanism (e.g. Oracle * RAWID, Sybase TIMESTAMP). * <p> * An implementation of this object must be re-entrant and thread * safe. It must depend on the connection passed in each method call * and never hold a reference to a connection. * * @author <a href="arkin@intalio.com">Assaf Arkin</a> * @version $Revision$ $Date: 2006-04-26 16:24:34 -0600 (Wed, 26 Apr 2006) $ * @see org.castor.persist.TransactionContext * @see org.exolab.castor.persist.spi.PersistenceQuery */ public interface Persistence { /** * Creates a new object in persistence storage. Called for an * object that was created during the transaction when the identity * of that object is known. Creates a new record in persistence * storage. Must detect an attempt to create an object with the * same identity and must retain a lock on the object after creation. * If the identity is null, an identity might be created and returned * by this method. * * @param conn An open connection * @param entity The fields to store * @param identity The object's identity * @return The object's identity * @throws PersistenceException An object with the same identity already * exists in persistent storage or any other persistence error * occured. */ Identity create(Database database, Object conn, ProposedEntity entity, Identity identity) throws PersistenceException; /** * Loads the object from persistence storage. This method will load * the object fields from persistence storage based on the object's * identity. This method may return a stamp which can be used at a * later point to determine whether the copy of the object in * persistence storage is newer than the cached copy (see {@link * #store}). If <tt>lock</tt> is true the object must be * locked in persistence storage to prevent concurrent updates. * * @param conn An open connection * @param proposedObject The fields to load into * @param identity object's identity * @param accessMode The access mode (null equals shared) * @throws PersistenceException The object was not found in persistent * storage or any other persistence error occured. */ void load(Object conn, ProposedEntity proposedObject, Identity identity, AccessMode accessMode) throws PersistenceException; /** * Stores the object in persistent storage, given the object fields * and its identity. The object has been loaded before or has been * created through a call to {@link #create}. This method should * detect whether the object has been modified in persistent storage * since it was loaded. After this method returns all locks on the * object must be retained until the transaction has completed. * This method may return a new stamp to track further updates to * the object. * <p> * If the object was not retrieved for exclusive access, this * method will be asked to perform dirty checking prior to storing * the object. The <tt>original</tt> argument will contains the * object's original fields as retrieved in the transaction, and * <tt>stamp</tt> the object's stamp returned from a successful * call to {@link #load}. These arguments are null for objects * retrieved with an exclusive lock. * * @param conn An open connection * @param newentity The fields to store * @param identity The object's identity * @param oldentity The original fields, or null * @throws PersistenceException The object has been modified in * persistence storage since it was last loaded or has been * deleted from persitence storage or any other persistence * error occored. */ void store(Object conn, Identity identity, ProposedEntity newentity, ProposedEntity oldentity) throws PersistenceException; /** * Deletes the object from persistent storage, given the object' * identity. The object has been loaded before or has been created * through a call to {@link #create}. After this method returns all * locks on the object must be retained until the transaction has * completed. * * @param conn An open connection * @param identity The object's identity * @throws PersistenceException A persistence error occured */ void delete(Object conn, Identity identity) throws PersistenceException; /** * Creates and returns a new query object. The query object is * used to execute a query against persistent storage and fetch * the results of the query. The query parameter types are * specified prehand. If a particular parameter type is unknown, * null may be used and type checking will defer to query * execution. * * @param query The query expression * @param types List of all parameter types, or null * @return A new query object that can be executed * @throws QueryException The query is invalid */ PersistenceQuery createQuery(QueryExpression query, Class<?>[] types, AccessMode accessMode) throws QueryException; SQLRelationLoader createSQLRelationLoader(String manyTable, String[] idSQL, int[] idType, TypeConvertor[] idTo, TypeConvertor[] idFrom, String[] relatedIdSQL, int[] relatedIdType, TypeConvertor[] ridTo, TypeConvertor[] ridFrom); }