/* * JBoss, Home of Professional Open Source * Copyright 2013, Red Hat, Inc. and/or its affiliates, and individual * contributors by the @authors tag. See the copyright.txt in the * distribution for a full listing of individual contributors. * * 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.jboss.as.quickstarts.xa; import javax.ejb.ActivationConfigProperty; import javax.ejb.MessageDriven; import javax.inject.Inject; import javax.jms.JMSException; import javax.jms.Message; import javax.jms.MessageListener; import javax.jms.TextMessage; import java.util.logging.Logger; /** * <p> * A Message Driven Bean that asynchronously receives and processes * messages of the form key=value and updates a database table with * those values using the services of an injected bean. * </p> * * @author Serge Pagop (spagop@redhat.com) * @author Mike Musgrove (mmusgrov@redhat.com) * */ @MessageDriven(name = "DbUpdaterMDB", activationConfig = { @ActivationConfigProperty(propertyName = "destinationType", propertyValue = "javax.jms.Queue"), @ActivationConfigProperty(propertyName = "destination", propertyValue = "queue/jta-crash-rec-quickstart"), @ActivationConfigProperty(propertyName = "acknowledgeMode", propertyValue = "Auto-acknowledge") }) public class DbUpdaterMDB implements MessageListener { private final static Logger LOGGER = Logger.getLogger(DbUpdaterMDB.class.getName()); // A helper service for persisting key value pairs @Inject private XAService xaService; public void onMessage(Message rcvMessage) { LOGGER.info("Received Message: " + rcvMessage.toString()); try { if (rcvMessage instanceof TextMessage) { TextMessage msg = (TextMessage) rcvMessage; String sm = msg.getText(); String[] kvPair = sm.split("="); // only process messages of the form key=value if (kvPair.length == 2 && kvPair[0].length() != 0) { xaService.modifyKeyValueTable(false, kvPair[0], kvPair[1] + " updated via JMS"); LOGGER.info("JTA Crash Record Quickstart: key value pair updated via JMS"); } } else { LOGGER.warning("JTA Crash Record Quickstart: Unexpected message. Type: " + rcvMessage.getClass().getName()); } } catch (JMSException e) { throw new RuntimeException(e); } } }