package org.jacorb.notification.servant; /* * JacORB - a free Java ORB * * Copyright (C) 1997-2014 Gerald Brose / The JacORB Team. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library 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 * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public * License along with this library; if not, write to the Free * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ import org.jacorb.config.Configuration; import org.jacorb.config.ConfigurationException; import org.jacorb.notification.MessageFactory; import org.jacorb.notification.OfferManager; import org.jacorb.notification.SubscriptionManager; import org.jacorb.notification.conf.Attributes; import org.jacorb.notification.conf.Default; import org.jacorb.notification.engine.TaskProcessor; import org.jacorb.notification.interfaces.Message; import org.jacorb.notification.interfaces.MessageSupplier; import org.omg.CORBA.Any; import org.omg.CORBA.BooleanHolder; import org.omg.CORBA.INTERNAL; import org.omg.CORBA.ORB; import org.omg.CosEventChannelAdmin.AlreadyConnected; import org.omg.CosEventComm.Disconnected; import org.omg.CosEventComm.PullSupplier; import org.omg.CosNotifyChannelAdmin.ProxyPullConsumerOperations; import org.omg.CosNotifyChannelAdmin.ProxyPullConsumerPOATie; import org.omg.CosNotifyChannelAdmin.ProxyType; import org.omg.PortableServer.POA; import org.omg.PortableServer.Servant; /** * @jmx.mbean extends = "AbstractProxyConsumerMBean" * @jboss.xmbean * * @author Alphonse Bendt */ public class ProxyPullConsumerImpl extends AbstractProxyConsumer implements ProxyPullConsumerOperations, MessageSupplier, MessageSupplierDelegate, ProxyPullConsumerImplMBean { /** * the connected PullSupplier */ private PullSupplier pullSupplier_; private long pollInterval_; private final PullMessagesOperation pullMessagesOperation_; private final PullMessagesUtility pollTaskUtility_; // ////////////////////////////////////// public ProxyPullConsumerImpl(IAdmin admin, ORB orb, POA poa, Configuration conf, TaskProcessor taskProcessor, MessageFactory messageFactory, OfferManager offerManager, SubscriptionManager subscriptionManager) { super(admin, orb, poa, conf, taskProcessor, messageFactory, null, offerManager, subscriptionManager); try { pollInterval_ = conf.getAttributeAsLong(Attributes.PULL_CONSUMER_POLL_INTERVAL, Default.DEFAULT_PULL_CONSUMER_POLL_INTERVAL); } catch (ConfigurationException ex) { logger_.error ("Error configuring ProxyPullConsumerImpl ", ex); throw new INTERNAL ("Error configuring ProxyPullConsumerImpl " + ex); } pullMessagesOperation_ = new PullMessagesOperation(this); pollTaskUtility_ = new PullMessagesUtility(taskProcessor, this); } // ////////////////////////////////////// public ProxyType MyType() { return ProxyType.PULL_ANY; } public void disconnect_pull_consumer() { destroy(); } protected void disconnectClient() { stopTask(); pullSupplier_.disconnect_pull_supplier(); pullSupplier_ = null; } protected void connectionSuspended() { stopTask(); } protected void connectionResumed() { startTask(); } public void runPullMessage() throws Disconnected { pullMessagesOperation_.runPull(); } public void connect_any_pull_supplier(PullSupplier pullSupplier) throws AlreadyConnected { checkIsNotConnected(); pullSupplier_ = pullSupplier; connectClient(pullSupplier); startTask(); } private synchronized void startTask() { pollTaskUtility_.startTask(pollInterval_); } private synchronized void stopTask() { pollTaskUtility_.stopTask(); } public Servant newServant() { return new ProxyPullConsumerPOATie(this); } // ////////////////////////////////////// // todo collect management informations public long getPollInterval() { return pollInterval_; } public long getPullTimer() { return pullMessagesOperation_.getTimeSpentInPull(); } public int getPullCounter() { return pullMessagesOperation_.getPullCounter(); } public int getSuccessfulPullCounter() { return pullMessagesOperation_.getSuccessfulPullCounter(); } public MessageSupplierDelegate.PullResult pullMessages() throws Disconnected { BooleanHolder _hasEvent = new BooleanHolder(); Any _event = pullSupplier_.try_pull(_hasEvent); return new MessageSupplierDelegate.PullResult(_event, _hasEvent.value); } public void queueMessages(PullResult data) { Message _message = getMessageFactory().newMessage((Any) data.data_, this); checkMessageProperties(_message); processMessage(_message); } }