package org.jacorb.notification.servant; /* * JacORB - a free Java ORB * * Copyright (C) 1999-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.BooleanHolder; import org.omg.CORBA.INTERNAL; import org.omg.CORBA.ORB; import org.omg.CosEventChannelAdmin.AlreadyConnected; import org.omg.CosEventComm.Disconnected; import org.omg.CosNotification.StructuredEvent; import org.omg.CosNotifyChannelAdmin.ProxyType; import org.omg.CosNotifyChannelAdmin.SequenceProxyPullConsumerOperations; import org.omg.CosNotifyChannelAdmin.SequenceProxyPullConsumerPOATie; import org.omg.CosNotifyChannelAdmin.SupplierAdmin; import org.omg.CosNotifyComm.SequencePullSupplier; import org.omg.PortableServer.POA; import org.omg.PortableServer.Servant; /** * @jmx.mbean extends = "AbstractProxyConsumerMBean" * @jboss.xmbean * * @author Alphonse Bendt */ public class SequenceProxyPullConsumerImpl extends AbstractProxyConsumer implements SequenceProxyPullConsumerOperations, SequenceProxyPullConsumerImplMBean, MessageSupplier, MessageSupplierDelegate { private SequencePullSupplier sequencePullSupplier_; private final PullMessagesUtility pollTaskUtility_; private final long pollInterval_; private final PullMessagesOperation pullMessagesOperation_; // ////////////////////////////////////// public SequenceProxyPullConsumerImpl(IAdmin admin, ORB orb, POA poa, Configuration config, TaskProcessor taskProcessor, MessageFactory messageFactory, OfferManager offerManager, SubscriptionManager subscriptionManager, SupplierAdmin supplierAdmin) { super(admin, orb, poa, config, taskProcessor, messageFactory, supplierAdmin, offerManager, subscriptionManager); try { pollInterval_ = config.getAttributeAsLong(Attributes.PULL_CONSUMER_POLL_INTERVAL, Default.DEFAULT_PULL_CONSUMER_POLL_INTERVAL); } catch (ConfigurationException ex) { logger_.error ("Error configuring SequenceProxyPullConsumerImpl ", ex); throw new INTERNAL ("Error configuring SequenceProxyPullConsumerImpl " + ex); } pollTaskUtility_ = new PullMessagesUtility(taskProcessor, this); pullMessagesOperation_ = new PullMessagesOperation(this); } public ProxyType MyType() { return ProxyType.PULL_SEQUENCE; } public void disconnect_sequence_pull_consumer() { destroy(); } public synchronized void connect_sequence_pull_supplier( SequencePullSupplier sequencePullSupplier) throws AlreadyConnected { checkIsNotConnected(); sequencePullSupplier_ = sequencePullSupplier; connectClient(sequencePullSupplier); pollTaskUtility_.startTask(pollInterval_); } protected void disconnectClient() { pollTaskUtility_.stopTask(); sequencePullSupplier_.disconnect_sequence_pull_supplier(); sequencePullSupplier_ = null; } public Servant newServant() { return new SequenceProxyPullConsumerPOATie(this); } public MessageSupplierDelegate.PullResult pullMessages() throws Disconnected { BooleanHolder _hasEvent = new BooleanHolder(); _hasEvent.value = false; StructuredEvent[] _events = sequencePullSupplier_.try_pull_structured_events(1, _hasEvent); return new MessageSupplierDelegate.PullResult(_events, _hasEvent.value); } public void queueMessages(PullResult pullResult) { StructuredEvent[] _events = (StructuredEvent[]) pullResult.data_; Message[] _messages = newMessages(_events); for (int x = 0; x < _messages.length; ++x) { processMessage(_messages[x]); } } public void runPullMessage() throws Disconnected { pullMessagesOperation_.runPull(); } }