Author: matthieu
Date: Tue Nov 3 16:48:15 2015
New Revision: 1712332
URL: http://svn.apache.org/viewvc?rev=1712332&view=rev
Log:
JAMES-1626 Add ActiveMQ support to cassandra-guice application
Added:
james/project/trunk/server/container/cassandra-guice/src/main/java/org/apache/james/modules/server/ActiveMQQueueModule.java
james/project/trunk/server/container/cassandra-guice/src/main/java/org/apache/james/modules/server/EmbeddedActiveMQ.java
Modified:
james/project/trunk/server/container/cassandra-guice/src/main/java/org/apache/james/CassandraJamesServerMain.java
Modified:
james/project/trunk/server/container/cassandra-guice/src/main/java/org/apache/james/CassandraJamesServerMain.java
URL:
http://svn.apache.org/viewvc/james/project/trunk/server/container/cassandra-guice/src/main/java/org/apache/james/CassandraJamesServerMain.java?rev=1712332&r1=1712331&r2=1712332&view=diff
==============================================================================
---
james/project/trunk/server/container/cassandra-guice/src/main/java/org/apache/james/CassandraJamesServerMain.java
(original)
+++
james/project/trunk/server/container/cassandra-guice/src/main/java/org/apache/james/CassandraJamesServerMain.java
Tue Nov 3 16:48:15 2015
@@ -25,6 +25,7 @@ import org.apache.james.modules.data.Cas
import org.apache.james.modules.mailbox.CassandraMailboxModule;
import org.apache.james.modules.mailbox.CassandraSessionModule;
import org.apache.james.modules.mailbox.ElasticSearchMailboxModule;
+import org.apache.james.modules.server.ActiveMQQueueModule;
import org.apache.james.modules.server.ConfigurationPerformerModule;
import org.apache.james.modules.server.DNSServiceModule;
@@ -41,7 +42,8 @@ public class CassandraJamesServerMain {
new CassandraUsersRepositoryModule(),
new CassandraDomainListModule(),
new CassandraRecipientRewriteTableModule(),
- new DNSServiceModule());
+ new DNSServiceModule(),
+ new ActiveMQQueueModule());
public static void main(String[] args) throws Exception {
CassandraJamesServer server = new CassandraJamesServer(defaultModule);
Added:
james/project/trunk/server/container/cassandra-guice/src/main/java/org/apache/james/modules/server/ActiveMQQueueModule.java
URL:
http://svn.apache.org/viewvc/james/project/trunk/server/container/cassandra-guice/src/main/java/org/apache/james/modules/server/ActiveMQQueueModule.java?rev=1712332&view=auto
==============================================================================
---
james/project/trunk/server/container/cassandra-guice/src/main/java/org/apache/james/modules/server/ActiveMQQueueModule.java
(added)
+++
james/project/trunk/server/container/cassandra-guice/src/main/java/org/apache/james/modules/server/ActiveMQQueueModule.java
Tue Nov 3 16:48:15 2015
@@ -0,0 +1,57 @@
+/****************************************************************
+ * Licensed to the Apache Software Foundation (ASF) under one *
+ * or more contributor license agreements. See the NOTICE file *
+ * distributed with this work for additional information *
+ * regarding copyright ownership. The ASF licenses this file *
+ * to you 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.apache.james.modules.server;
+
+import com.google.inject.AbstractModule;
+import com.google.inject.Provides;
+import com.google.inject.Singleton;
+import org.apache.james.queue.activemq.ActiveMQMailQueueFactory;
+import org.apache.james.queue.api.MailQueueFactory;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+
+import javax.jms.ConnectionFactory;
+
+public class ActiveMQQueueModule extends AbstractModule {
+
+ private static Logger LOGGER =
LoggerFactory.getLogger(ActiveMQQueueModule.class);
+
+ @Override
+ protected void configure() {
+
+ }
+
+ @Provides
+ @Singleton
+ ConnectionFactory provideEmbededActiveMQ(EmbeddedActiveMQ
embeddedActiveMQ) {
+ return embeddedActiveMQ.getConnectionFactory();
+ }
+
+ @Provides
+ @Singleton
+ public MailQueueFactory createActiveMailQueueFactory(ConnectionFactory
connectionFactory, ActiveMQMailQueueFactory activeMQMailQueueFactory) {
+ activeMQMailQueueFactory.setUseJMX(true);
+ activeMQMailQueueFactory.setConnectionFactory(connectionFactory);
+ activeMQMailQueueFactory.setLog(LOGGER);
+ activeMQMailQueueFactory.init();
+ return activeMQMailQueueFactory;
+ }
+
+}
Added:
james/project/trunk/server/container/cassandra-guice/src/main/java/org/apache/james/modules/server/EmbeddedActiveMQ.java
URL:
http://svn.apache.org/viewvc/james/project/trunk/server/container/cassandra-guice/src/main/java/org/apache/james/modules/server/EmbeddedActiveMQ.java?rev=1712332&view=auto
==============================================================================
---
james/project/trunk/server/container/cassandra-guice/src/main/java/org/apache/james/modules/server/EmbeddedActiveMQ.java
(added)
+++
james/project/trunk/server/container/cassandra-guice/src/main/java/org/apache/james/modules/server/EmbeddedActiveMQ.java
Tue Nov 3 16:48:15 2015
@@ -0,0 +1,104 @@
+/****************************************************************
+ * Licensed to the Apache Software Foundation (ASF) under one *
+ * or more contributor license agreements. See the NOTICE file *
+ * distributed with this work for additional information *
+ * regarding copyright ownership. The ASF licenses this file *
+ * to you 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.apache.james.modules.server;
+
+import com.google.common.base.Throwables;
+import com.google.inject.Inject;
+import com.google.inject.Singleton;
+import org.apache.activemq.ActiveMQConnectionFactory;
+import org.apache.activemq.ActiveMQPrefetchPolicy;
+import org.apache.activemq.blob.BlobTransferPolicy;
+import org.apache.activemq.broker.BrokerPlugin;
+import org.apache.activemq.broker.BrokerService;
+import org.apache.activemq.broker.jmx.ManagementContext;
+import org.apache.activemq.plugin.StatisticsBrokerPlugin;
+import org.apache.activemq.store.amq.AMQPersistenceAdapter;
+import org.apache.james.queue.activemq.FileSystemBlobTransferPolicy;
+
+import javax.annotation.PreDestroy;
+import javax.jms.ConnectionFactory;
+
+@Singleton
+public class EmbeddedActiveMQ {
+
+ private ActiveMQConnectionFactory activeMQConnectionFactory;
+ private BrokerService brokerService;
+
+ @Inject private EmbeddedActiveMQ() {
+ try {
+ launchEmbeddedBroker();
+ } catch (Exception e) {
+ throw Throwables.propagate(e);
+ }
+ activeMQConnectionFactory =
createActiveMQConnectionFactory(createBlobTransferPolicy());
+ }
+
+ public ConnectionFactory getConnectionFactory() {
+ return activeMQConnectionFactory;
+ }
+
+ @PreDestroy
+ public void stop() throws Exception {
+ brokerService.stop();
+ }
+
+ private ActiveMQConnectionFactory
createActiveMQConnectionFactory(BlobTransferPolicy blobTransferPolicy) {
+ ActiveMQConnectionFactory connectionFactory = new
ActiveMQConnectionFactory("vm://james?create=false");
+ connectionFactory.setBlobTransferPolicy(blobTransferPolicy);
+ connectionFactory.setPrefetchPolicy(createActiveMQPrefetchPolicy());
+ return connectionFactory;
+ }
+
+ private ActiveMQPrefetchPolicy createActiveMQPrefetchPolicy() {
+ ActiveMQPrefetchPolicy prefetchPolicy = new ActiveMQPrefetchPolicy();
+ prefetchPolicy.setQueuePrefetch(0);
+ prefetchPolicy.setTopicPrefetch(0);
+ return prefetchPolicy;
+ }
+
+ private BlobTransferPolicy createBlobTransferPolicy() {
+ BlobTransferPolicy blobTransferPolicy = new
FileSystemBlobTransferPolicy();
+
blobTransferPolicy.setDefaultUploadUrl("file://var/store/activemq/blob-transfer");
+ return blobTransferPolicy;
+ }
+
+ private void launchEmbeddedBroker() throws Exception {
+ brokerService = new BrokerService();
+ brokerService.setBrokerName("james");
+ brokerService.setUseJmx(false);
+ brokerService.setPersistent(true);
+
brokerService.setDataDirectory("filesystem=file://var/store/activemq/brokers");
+ brokerService.setUseShutdownHook(false);
+ brokerService.setSchedulerSupport(false);
+ brokerService.setBrokerId("broker");
+ String[] uris = {"tcp://localhost:0"};
+ brokerService.setTransportConnectorURIs(uris);
+ ManagementContext managementContext = new ManagementContext();
+ managementContext.setCreateConnector(false);
+ brokerService.setManagementContext(managementContext);
+ brokerService.setPersistenceAdapter(new AMQPersistenceAdapter());
+ BrokerPlugin[] brokerPlugins = {new StatisticsBrokerPlugin()};
+ brokerService.setPlugins(brokerPlugins);
+ String[] transportConnectorsURIs = {"tcp://localhost:0"};
+ brokerService.setTransportConnectorURIs(transportConnectorsURIs);
+ brokerService.start();
+ System.out.println("Started : " + brokerService.isStarted());
+ }
+}
---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]