?? persistenceadapter.java
字號:
/**
* 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 Exoffice Technologies. 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 Exoffice Technologies. Exolab is a registered
* trademark of Exoffice Technologies.
*
* 5. Due credit should be given to the Exolab Project
* (http://www.exolab.org/).
*
* THIS SOFTWARE IS PROVIDED BY EXOFFICE TECHNOLOGIES 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
* EXOFFICE TECHNOLOGIES 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 2000-2005 (C) Exoffice Technologies Inc. All Rights Reserved.
*
* $Id: PersistenceAdapter.java,v 1.2 2005/03/18 04:05:52 tanderson Exp $
*/
package org.exolab.jms.persistence;
import java.sql.Connection;
import java.util.Enumeration;
import java.util.HashMap;
import java.util.Vector;
import org.exolab.jms.authentication.User;
import org.exolab.jms.client.JmsDestination;
import org.exolab.jms.message.MessageImpl;
import org.exolab.jms.messagemgr.MessageHandle;
/**
* This adapter is a wrapper class around the persistency mechanism.
* It isolates the client from the working specifics of the database, by
* providing a simple straight forward interface. Future changes to
* the database will only require changes to the adapter.
*
* @version $Revision: 1.2 $ $Date: 2005/03/18 04:05:52 $
* @author <a href="mailto:mourikis@exolab.org">Jim Mourikis</a>
* @see org.exolab.jms.persistence.RDBMSAdapter
*/
public abstract class PersistenceAdapter {
/**
* Close the database if open.
*
*/
public abstract void close();
/**
* Check to see if the root is created. If its not then create it
* and initialise it to 0.
* Return the value of this root id.
*
* @return long The id of the last batch.
* @throws PersistenceException
*/
public abstract long getLastId(Connection connection)
throws PersistenceException;
/**
* Update the given id.
*
* @param connection - the connection to use
* @param id The id to set in the database.
* @throws PersistenceException
*/
public abstract void updateIds(Connection connection, long id)
throws PersistenceException;
/**
* Add a new message to the database.
*
* @param connection the connection to use
* @param message the new message to add
* @throws PersistenceException
*/
public abstract void addMessage(Connection connection,
MessageImpl message)
throws PersistenceException;
/**
* Update this message in the database
*
* @param connection the connection to use
* @param message the message to update
* @throws PersistenceException
*/
public abstract void updateMessage(Connection connection,
MessageImpl message)
throws PersistenceException;
/**
* Remove the message with the specified identity from the database
*
* @param connection - the connection to use
* @param id the identity of the message to remove
* @throws PersistenceException
*/
public abstract void removeMessage(Connection connection,
String id)
throws PersistenceException;
/**
* Remove all expired messages and associated references from the
* database. It uses the current time to determine messages that
* have exipred.
*
* @param connection - the connection to use
* @throws PersistenceException
*/
public abstract void removeExpiredMessages(Connection connection)
throws PersistenceException;
/**
* Remove all expired messages handles associated with this durable
* consumer.
*
* @param connection - the connection to use
* @param consumer - the durable consumer name
* @throws PersistenceException
*/
public abstract void removeExpiredMessageHandles(Connection connection,
String consumer)
throws PersistenceException;
/**
* Retrieve a list of unexpired {@link MessageHandle} objects,
* for the specified destination.
*
* @param connection - the connection to use
* @param destination - the destination in question
* @return Vector - collection of unexpired message handles
* @throws PersistenceException
*/
public abstract Vector getNonExpiredMessages(Connection connection,
JmsDestination destination)
throws PersistenceException;
/**
* Get a message from the persistence store.
*
* @param connection - the connection to use
* @param id the id of the message to search for
* @return MessageImpl The message if found otherwise null
* @throws PersistenceException
*/
public abstract MessageImpl getMessage(Connection connection,
String id)
throws PersistenceException;
/**
* Get at least the next message given the specified persistent
* handle. The handle encodes all the information, including destination
* and timestamp, required to fetch that and successive messages. This
* will fault in more than one message for performance
*
* @param connection - the connection to use
* @param handle - the persistent handle to resolve
* @return Vector - a vector of MessageImpl
* @throws PersistenceException
*/
public abstract Vector getMessages(Connection connection,
MessageHandle handle)
throws PersistenceException;
/**
* Return a list of unprocessed messages. These are messages that have
* been stored in the database but not processed.
*
* @param connection - the connection to use
* @return Vector - a collection of un processed messages
* @throws PersistenceException
*/
public abstract Vector getUnprocessedMessages(Connection connection)
throws PersistenceException;
/**
* Add the specified persistent message handle.
*
* @param connection - the connection to use
* @param handle - the persistent handle to add
* @throws PersistenceException
*/
public abstract void addMessageHandle(Connection connection,
MessageHandle handle)
throws PersistenceException;
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -