/* * JBoss, Home of Professional Open Source * Copyright 2005-2008, Red Hat Middleware LLC, and individual contributors * by the @authors tag. See the copyright.txt in the distribution for a * full listing of individual contributors. * * This is free software; you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation; either version 2.1 of * the License, or (at your option) any later version. * * This software 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this software; if not, write to the Free * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA, or see the FSF site: http://www.fsf.org. */ package org.jboss.messaging.core.paging; import org.jboss.messaging.core.journal.SequentialFile; import org.jboss.messaging.core.postoffice.PostOffice; import org.jboss.messaging.core.server.MessagingComponent; import org.jboss.messaging.core.server.ServerMessage; import org.jboss.messaging.util.SimpleString; import java.util.Collection; /** * * <p>Look at the <a href="http://wiki.jboss.org/wiki/JBossMessaging2Paging">WIKI</a> for more information.</p> * <PRE> +------------+ 1 +-------------+ N +------------+ N +-------+ 1 +----------------+ | {@link PostOffice} |-------> |PagingManager|-------> |{@link PagingStore} | ------> | {@link Page} | ------> | {@link SequentialFile} | +------------+ +-------------+ +------------+ +-------+ +----------------+ | 1 ^ | | | | | | 1 | N +-------------------+ +--------> | DestinationAdress | +-------------------+ </PRE> * * @author <a href="mailto:clebert.suconic@jboss.com">Clebert Suconic</a> * @author <a href="mailto:tim.fox@jboss.com">Tim Fox</a> * @author <a href="mailto:andy.taylor@jboss.org>Andy Taylor</a> * */ public interface PagingManager extends MessagingComponent { boolean isGlobalPageMode(); /** To return the PageStore associated with the address */ PagingStore getPageStore(SimpleString address) throws Exception; /** An injection point for the PostOffice to inject itself */ void setPostOffice(PostOffice postOffice); /** * @param pagingStoreImpl * @return false if the listener can't handle more pages */ boolean onDepage(int pageId, SimpleString destination, PagingStore pagingStoreImpl, PageMessage[] data) throws Exception; /** * To be used by transactions only. * If you're sure you will page if isPaging, just call the method page and look at its return. * @param destination * @return */ boolean isPaging(SimpleString destination) throws Exception; /** * Page, only if destination is in page mode. * @param message * @return false if destination is not on page mode */ boolean page(ServerMessage message) throws Exception; /** * Page, only if destination is in page mode. * @param message * @return false if destination is not on page mode */ boolean pageScheduled(ServerMessage message, long scheduledDeliveryTime) throws Exception; /** * Page, only if destination is in page mode. * @param message * @return false if destination is not on page mode */ boolean page(ServerMessage message, long transactionId) throws Exception; /** * Page, only if destination is in page mode. * @param message * @return false if destination is not on page mode */ boolean pageScheduled(ServerMessage message, long transactionId, long scheduledDeliveryTime) throws Exception; /** * Point to inform/restoring Transactions used when the messages were added into paging * */ void addTransaction(PageTransactionInfo pageTransaction); /** * * Duplication detection for paging processing * */ void setLastPage(LastPageRecord lastPage) throws Exception; /** * * To be called when there are no more references to the message * @param message */ void messageDone(ServerMessage message) throws Exception; /** To be called when an message is being added to the address. * @return the current size of the queue, or -1 if the queue is full and it should drop the message */ long addSize(ServerMessage message) throws Exception; /** Sync current-pages on disk for these destinations */ void sync(Collection<SimpleString> destinationsToSync) throws Exception; /** * When we stop depaging, The Last page record needs to removed. * Or else the record could live forever on the journal. * @throws Exception * */ void clearLastPageRecord(LastPageRecord lastRecord) throws Exception; }