001 /*
002 GRANITE DATA SERVICES
003 Copyright (C) 2011 GRANITE DATA SERVICES S.A.S.
004
005 This file is part of Granite Data Services.
006
007 Granite Data Services is free software; you can redistribute it and/or modify
008 it under the terms of the GNU Library General Public License as published by
009 the Free Software Foundation; either version 2 of the License, or (at your
010 option) any later version.
011
012 Granite Data Services is distributed in the hope that it will be useful, but
013 WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
014 FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public License
015 for more details.
016
017 You should have received a copy of the GNU Library General Public License
018 along with this library; if not, see <http://www.gnu.org/licenses/>.
019 */
020
021 package org.granite.gravity.adapters;
022
023 import javax.jms.Session;
024
025 import org.apache.activemq.ActiveMQConnectionFactory;
026 import org.apache.activemq.command.ActiveMQTopic;
027 import org.granite.logging.Logger;
028 import org.granite.messaging.service.ServiceException;
029 import org.granite.util.XMap;
030
031 /**
032 * @author William DRAI
033 */
034 public class ActiveMQServiceAdapter extends JMSServiceAdapter {
035
036 private static final Logger log = Logger.getLogger(ActiveMQServiceAdapter.class);
037
038 @Override
039 public void configure(XMap adapterProperties, XMap destinationProperties) throws ServiceException {
040 try {
041 destinationName = destinationProperties.get("jms/destination-name");
042 if (Boolean.TRUE.toString().equals(destinationProperties.get("jms/transacted-sessions")))
043 transactedSessions = true;
044 if ("AUTO_ACKNOWLEDGE".equals(destinationProperties.get("jms/acknowledge-mode")))
045 acknowledgeMode = Session.AUTO_ACKNOWLEDGE;
046 else if ("CLIENT_ACKNOWLEDGE".equals(destinationProperties.get("jms/acknowledge-mode")))
047 acknowledgeMode = Session.CLIENT_ACKNOWLEDGE;
048 else if ("DUPS_OK_ACKNOWLEDGE".equals(destinationProperties.get("jms/acknowledge-mode")))
049 acknowledgeMode = Session.DUPS_OK_ACKNOWLEDGE;
050 if ("javax.jms.TextMessage".equals(destinationProperties.get("jms/message-type")))
051 textMessages = true;
052
053 if (Boolean.TRUE.toString().equals(destinationProperties.get("jms/no-local")))
054 noLocal = true;
055
056 if (Boolean.TRUE.toString().equals(destinationProperties.get("session-selector")))
057 sessionSelector = true;
058
059 failoverRetryInterval = destinationProperties.get("jms/failover-retry-interval", Long.TYPE, DEFAULT_FAILOVER_RETRY_INTERVAL);
060 if (failoverRetryInterval <= 0) {
061 log.warn("Illegal failover retry interval: %d (using default %d)", failoverRetryInterval, DEFAULT_FAILOVER_RETRY_INTERVAL);
062 failoverRetryInterval = DEFAULT_FAILOVER_RETRY_INTERVAL;
063 }
064
065 failoverRetryCount = destinationProperties.get("jms/failover-retry-count", Integer.TYPE, DEFAULT_FAILOVER_RETRY_COUNT);
066 if (failoverRetryCount <= 0) {
067 log.warn("Illegal failover retry count: %s (using default %d)", failoverRetryCount, DEFAULT_FAILOVER_RETRY_COUNT);
068 failoverRetryCount = DEFAULT_FAILOVER_RETRY_COUNT;
069 }
070
071 StringBuilder sb = null;
072 if (destinationProperties.get("server/broker-url") != null && !"".equals(destinationProperties.get("server/broker-url").trim())) {
073 sb = new StringBuilder(destinationProperties.get("server/broker-url"));
074 }
075 else {
076 sb = new StringBuilder("vm://");
077 sb.append(getId());
078 if (Boolean.FALSE.toString().equals(destinationProperties.get("server/create-broker"))) {
079 sb.append("?create=false");
080 String startupWait = destinationProperties.get("server/wait-for-start");
081 if (startupWait != null)
082 sb.append("&waitForStart=" + startupWait);
083 }
084 else
085 sb.append("?create=true");
086
087 if (Boolean.TRUE.toString().equals(destinationProperties.get("server/durable"))) {
088 sb.append("&broker.persistent=true");
089 if (destinationProperties.containsKey("server/file-store-root"))
090 sb.append("&broker.dataDirectory=").append(destinationProperties.get("server/file-store-root"));
091 }
092 else
093 sb.append("&broker.persistent=false");
094 }
095
096 String brokerURL = sb.toString();
097 if (destinationProperties.get("server/username") != null && !"".equals(destinationProperties.get("server/username").trim())
098 && destinationProperties.get("server/password") != null && !"".equals(destinationProperties.get("server/password").trim())) {
099 String username = destinationProperties.get("server/username");
100 String password = destinationProperties.get("server/password");
101 jmsConnectionFactory = new ActiveMQConnectionFactory(username, password, brokerURL);
102 }
103 else
104 jmsConnectionFactory = new ActiveMQConnectionFactory(brokerURL);
105 }
106 catch (Exception e) {
107 throw new ServiceException("Error when configuring JMS Adapter", e);
108 }
109 }
110
111 @Override
112 protected javax.jms.Destination getProducerDestination(String topic) {
113 return new ActiveMQTopic(topic != null ? destinationName + "." + topic.replaceAll("\\*\\*", ">") : destinationName);
114 }
115
116 @Override
117 protected javax.jms.Destination getConsumerDestination(String topic) {
118 return new ActiveMQTopic(topic != null ? destinationName + "." + topic.replaceAll("\\*\\*", ">") : destinationName);
119 }
120 }