/* * * 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. * */ package org.apache.qpid.server.queue; import static org.apache.qpid.server.logging.subjects.LogSubjectFormat.SUBSCRIPTION_FORMAT; import java.text.MessageFormat; import java.util.EnumMap; import java.util.EnumSet; import java.util.HashMap; import java.util.Iterator; import java.util.Map; import java.util.UUID; import java.util.concurrent.atomic.AtomicBoolean; import java.util.concurrent.atomic.AtomicLong; import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReentrantLock; import org.apache.log4j.Logger; import org.apache.qpid.server.consumer.ConsumerTarget; import org.apache.qpid.server.filter.FilterManager; import org.apache.qpid.server.filter.JMSSelectorFilter; import org.apache.qpid.server.filter.MessageFilter; import org.apache.qpid.server.logging.EventLogger; import org.apache.qpid.server.logging.LogSubject; import org.apache.qpid.server.logging.messages.SubscriptionMessages; import org.apache.qpid.server.logging.subjects.QueueLogSubject; import org.apache.qpid.server.message.MessageInstance; import org.apache.qpid.server.message.MessageSource; import org.apache.qpid.server.message.ServerMessage; import org.apache.qpid.server.model.AbstractConfiguredObject; import org.apache.qpid.server.model.LifetimePolicy; import org.apache.qpid.server.model.ManagedAttributeField; import org.apache.qpid.server.model.State; import org.apache.qpid.server.protocol.AMQSessionModel; import org.apache.qpid.server.protocol.MessageConverterRegistry; import org.apache.qpid.server.util.StateChangeListener; class QueueConsumerImpl extends AbstractConfiguredObject implements QueueConsumer, LogSubject { private static final Logger _logger = Logger.getLogger(QueueConsumerImpl.class); private final AtomicBoolean _targetClosed = new AtomicBoolean(false); private final AtomicBoolean _closed = new AtomicBoolean(false); private final long _consumerNumber; private final Lock _stateChangeLock = new ReentrantLock(); private final long _createTime = System.currentTimeMillis(); private final MessageInstance.ConsumerAcquiredState _owningState = new MessageInstance.ConsumerAcquiredState(this); private final boolean _acquires; private final boolean _seesRequeues; private final boolean _isTransient; private final AtomicLong _deliveredCount = new AtomicLong(0); private final AtomicLong _deliveredBytes = new AtomicLong(0); private final FilterManager _filters; private final Class _messageClass; private final Object _sessionReference; private final AbstractQueue _queue; static final EnumMap STATE_MAP = new EnumMap(ConsumerTarget.State.class); static { STATE_MAP.put(ConsumerTarget.State.ACTIVE, State.ACTIVE); STATE_MAP.put(ConsumerTarget.State.SUSPENDED, State.QUIESCED); STATE_MAP.put(ConsumerTarget.State.CLOSED, State.DELETED); } private final ConsumerTarget _target; private final SubFlushRunner _runner = new SubFlushRunner(this); private volatile QueueContext _queueContext; private StateChangeListener _stateListener = new StateChangeListener() { public void stateChanged(QueueConsumerImpl sub, State oldState, State newState) { getEventLogger().message(QueueConsumerImpl.this, SubscriptionMessages.STATE(newState.toString())); } }; @ManagedAttributeField private boolean _exclusive; @ManagedAttributeField private boolean _noLocal; @ManagedAttributeField private String _distributionMode; @ManagedAttributeField private String _settlementMode; @ManagedAttributeField private String _selector; QueueConsumerImpl(final AbstractQueue queue, ConsumerTarget target, final String consumerName, final FilterManager filters, final Class messageClass, EnumSet