/*
* JBoss, Home of Professional Open Source
* Copyright 2013, Red Hat, Inc. 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.richfaces.application.push.impl;
import java.text.MessageFormat;
import java.util.List;
import java.util.concurrent.CopyOnWriteArrayList;
import org.richfaces.application.push.MessageDataSerializer;
import org.richfaces.application.push.MessageException;
import org.richfaces.application.push.Session;
import org.richfaces.application.push.SessionPreSubscriptionEvent;
import org.richfaces.application.push.SubscriptionFailureException;
import org.richfaces.application.push.Topic;
import org.richfaces.application.push.TopicEvent;
import org.richfaces.application.push.TopicKey;
import org.richfaces.application.push.TopicListener;
import org.richfaces.log.Logger;
import org.richfaces.log.RichfacesLogger;
/**
* Topic encapsulates particular endpoint for sending/receiving messages.
*
* @author Nick Belaevski
*
* @see Topic
*/
public abstract class AbstractTopic implements Topic {
private static final Logger LOGGER = RichfacesLogger.APPLICATION.getLogger();
private TopicKey key;
private volatile MessageDataSerializer serializer;
private volatile boolean allowSubtopics;
private List<TopicListener> listeners = new CopyOnWriteArrayList<TopicListener>();
public AbstractTopic(TopicKey key) {
super();
this.key = key;
}
/*
* (non-Javadoc)
* @see org.richfaces.application.push.Topic#getMessageDataSerializer()
*/
@Override
public MessageDataSerializer getMessageDataSerializer() {
if (serializer == null) {
return DefaultMessageDataSerializer.instance();
}
return serializer;
}
/*
* (non-Javadoc)
* @see org.richfaces.application.push.Topic#setMessageDataSerializer(org.richfaces.application.push.MessageDataSerializer)
*/
@Override
public void setMessageDataSerializer(MessageDataSerializer serializer) {
this.serializer = serializer;
}
/**
* Returns true if this topic allow to use subtopics
*/
public boolean isAllowSubtopics() {
return allowSubtopics;
}
/**
* Allow or disallow use of topics
*/
public void setAllowSubtopics(boolean allowSubtopics) {
this.allowSubtopics = allowSubtopics;
}
/*
* (non-Javadoc)
* @see org.richfaces.application.push.Topic#getKey()
*/
@Override
public TopicKey getKey() {
return key;
}
/*
* (non-Javadoc)
* @see org.richfaces.application.push.Topic#addTopicListener(org.richfaces.application.push.TopicListener)
*/
@Override
public void addTopicListener(TopicListener topicListener) {
TopicListener listener = topicListener;
listeners.add(listener);
}
/*
* (non-Javadoc)
* @see org.richfaces.application.push.Topic#removeTopicListener(org.richfaces.application.push.TopicListener)
*/
@Override
public void removeTopicListener(TopicListener topicListener) {
listeners.remove(topicListener);
}
/*
* (non-Javadoc)
* @see org.richfaces.application.push.Topic#checkSubscription(org.richfaces.application.push.Session)
*/
@Override
public void checkSubscription(TopicKey topicKey, Session session) throws SubscriptionFailureException {
SessionPreSubscriptionEvent event = new SessionPreSubscriptionEvent(this, topicKey, session);
for (TopicListener listener : listeners) {
if (event.isAppropriateListener(listener)) {
try {
event.invokeListener(listener);
} catch (SubscriptionFailureException e) {
throw e;
} catch (Exception e) {
logError(e);
}
}
}
}
private void logError(Exception e) {
LOGGER.error(MessageFormat.format("Exception invoking listener: {0}", e.getMessage()), e);
}
/*
* (non-Javadoc)
* @see org.richfaces.application.push.Topic#publishEvent(org.richfaces.application.push.TopicEvent)
*/
@Override
public void publishEvent(TopicEvent event) {
for (TopicListener listener : listeners) {
if (event.isAppropriateListener(listener)) {
try {
event.invokeListener(listener);
} catch (Exception e) {
logError(e);
}
}
}
}
/*
* (non-Javadoc)
* @see org.richfaces.application.push.Topic#publish(java.lang.Object)
*/
@Override
public abstract void publish(Object messageData) throws MessageException;
/*
* (non-Javadoc)
* @see org.richfaces.application.push.Topic#publish(java.lang.Object, java.lang.String)
*/
@Override
public abstract void publish(Object messageData, String subtopicName) throws MessageException;
}