package org.jboss.test.jmsra.bean;
import javax.ejb.MessageDrivenBean;
import javax.ejb.MessageDrivenContext;
import javax.ejb.EJBException;
import javax.naming.*;
import javax.jms.*;
import org.apache.log4j.Category;
public class TopicAdapter implements MessageDrivenBean, MessageListener{
private static final Category log = Category.getInstance(TopicAdapter.class);
private static final String CONNECTION_JNDI = "java:comp/env/jms/MyQueueConnection";
private static final String QUEUE_JNDI = "java:comp/env/jms/QueueName";
private MessageDrivenContext ctx = null;
private Queue queue = null;
private QueueConnection queueConnection = null;
public TopicAdapter() {
}
public void setMessageDrivenContext(MessageDrivenContext ctx)
{
this.ctx = ctx;
}
public void ejbCreate() {
try {
Context context = new InitialContext();
queue = (Queue)context.lookup(QUEUE_JNDI);
QueueConnectionFactory factory = (QueueConnectionFactory)context.lookup(CONNECTION_JNDI);
queueConnection = factory.createQueueConnection();
} catch (Exception ex) {
log.debug("failed", ex);
throw new EJBException(ex.toString());
}
}
public void ejbRemove() {
if(queueConnection != null) {
try {
queueConnection.close();
} catch (Exception e) {
log.debug("failed", e);
}
}
ctx=null;
}
public void onMessage(Message message) {
log.debug("TopicBean got message" + message.toString() );
QueueSession queueSession = null;
try {
QueueSender queueSender = null;
queueSession =
queueConnection.createQueueSession(true, Session.AUTO_ACKNOWLEDGE);
queueSender = queueSession.createSender(queue);
queueSender.send(message);
} catch (JMSException ex) {
log.debug("failed", ex);
ctx.setRollbackOnly();
throw new EJBException(ex.toString());
} finally {
if (queueSession != null) {
try {
queueSession.close();
} catch (Exception e) {
log.debug("failed", e);
}
}
}
}
}