+/*
+ * Copyright (C) 2010 Mathieu Baudier <mbaudier@argeo.org>
+ *
+ * Licensed 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.argeo.slc.jms;
import java.util.Map;
+import javax.jms.DeliveryMode;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.Message;
+import org.apache.commons.logging.Log;
+import org.apache.commons.logging.LogFactory;
+import org.argeo.slc.SlcException;
import org.argeo.slc.msg.event.SlcEvent;
import org.argeo.slc.msg.event.SlcEventPublisher;
import org.springframework.jms.core.JmsTemplate;
import org.springframework.jms.core.MessagePostProcessor;
public class JmsSlcEventPublisher implements SlcEventPublisher {
+ private static final Log log = LogFactory
+ .getLog(JmsSlcEventPublisher.class);
private Destination eventsDestination;
private JmsTemplate jmsTemplate;
public void publish(final SlcEvent event) {
+ if (jmsTemplate.getDeliveryMode() != DeliveryMode.PERSISTENT)
+ throw new SlcException(
+ "Delivery mode has to be persistent in order to have durable subscription");
+
jmsTemplate.convertAndSend(eventsDestination, event,
new MessagePostProcessor() {
return message;
}
});
- // jmsTemplate.send(eventsDestination, new MessageCreator() {
- // public Message createMessage(Session session) throws JMSException {
- // TextMessage msg = session.createTextMessage();
- // // TODO: remove workaround when upgrading to ActiveMQ 5.3
- // // Workaround for
- // // https://issues.apache.org/activemq/browse/AMQ-2046
- // msg.setText("");
- //
- // return msg;
- // }
- // });
+ if (log.isTraceEnabled()) {
+ log.trace("Event " + event.toString() + " sent to "
+ + eventsDestination.toString());
+ }
+
}
public void setEventsDestination(Destination eventsDestination) {