blob: be292459015478f31269cddfaefb2883c2715bc9 [file] [log] [blame]
package org.apache.qpid.server.queue;
import org.apache.qpid.AMQException;
import org.apache.qpid.server.subscription.Subscription;
import org.apache.qpid.server.message.ServerMessage;
/*
*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.
*
*/
public interface QueueEntry extends Comparable<QueueEntry>, Filterable
{
public static enum State
{
AVAILABLE,
ACQUIRED,
EXPIRED,
DEQUEUED,
DELETED;
}
public static interface StateChangeListener
{
public void stateChanged(QueueEntry entry, State oldSate, State newState);
}
public abstract class EntryState
{
private EntryState()
{
}
public abstract State getState();
/**
* Returns true if state is either DEQUEUED or DELETED.
*
* @return true if state is either DEQUEUED or DELETED.
*/
public boolean isDispensed()
{
State currentState = getState();
return currentState == State.DEQUEUED || currentState == State.DELETED;
}
}
public final class AvailableState extends EntryState
{
public State getState()
{
return State.AVAILABLE;
}
}
public final class DequeuedState extends EntryState
{
public State getState()
{
return State.DEQUEUED;
}
}
public final class DeletedState extends EntryState
{
public State getState()
{
return State.DELETED;
}
}
public final class ExpiredState extends EntryState
{
public State getState()
{
return State.EXPIRED;
}
}
public final class NonSubscriptionAcquiredState extends EntryState
{
public State getState()
{
return State.ACQUIRED;
}
}
public final class SubscriptionAcquiredState extends EntryState
{
private final Subscription _subscription;
public SubscriptionAcquiredState(Subscription subscription)
{
_subscription = subscription;
}
public State getState()
{
return State.ACQUIRED;
}
public Subscription getSubscription()
{
return _subscription;
}
}
public final class SubscriptionAssignedState extends EntryState
{
private final Subscription _subscription;
public SubscriptionAssignedState(Subscription subscription)
{
_subscription = subscription;
}
public State getState()
{
return State.AVAILABLE;
}
public Subscription getSubscription()
{
return _subscription;
}
}
final static EntryState AVAILABLE_STATE = new AvailableState();
final static EntryState DELETED_STATE = new DeletedState();
final static EntryState DEQUEUED_STATE = new DequeuedState();
final static EntryState EXPIRED_STATE = new ExpiredState();
final static EntryState NON_SUBSCRIPTION_ACQUIRED_STATE = new NonSubscriptionAcquiredState();
AMQQueue getQueue();
ServerMessage getMessage();
long getSize();
boolean getDeliveredToConsumer();
boolean expired() throws AMQException;
boolean isAvailable();
boolean isAcquired();
boolean acquire();
boolean acquire(Subscription sub);
boolean delete();
boolean isDeleted();
boolean acquiredBySubscription();
boolean isAcquiredBy(Subscription subscription);
void release();
boolean releaseButRetain();
boolean immediateAndNotDelivered();
void setRedelivered();
boolean isRedelivered();
Subscription getDeliveredSubscription();
void reject();
boolean isRejectedBy(long subscriptionId);
void dequeue();
void dispose();
void discard();
void routeToAlternate();
boolean isQueueDeleted();
void addStateChangeListener(StateChangeListener listener);
boolean removeStateChangeListener(StateChangeListener listener);
/**
* Returns true if entry is in DEQUEUED state, otherwise returns false.
*
* @return true if entry is in DEQUEUED state, otherwise returns false
*/
boolean isDequeued();
/**
* Returns true if entry is either DEQUED or DELETED state.
*
* @return true if entry is either DEQUED or DELETED state
*/
boolean isDispensed();
}