blob: aebbf325ac11d1cf86de2d9ef23064892e0fdba4 [file] [log] [blame]
/*
* 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;
import java.util.Set;
import org.apache.commons.lang3.NotImplementedException;
import org.apache.james.data.UsersRepositoryModuleChooser;
import org.apache.james.eventsourcing.eventstore.EventNestedTypes;
import org.apache.james.jmap.JMAPListenerModule;
import org.apache.james.json.DTO;
import org.apache.james.json.DTOModule;
import org.apache.james.modules.BlobExportMechanismModule;
import org.apache.james.modules.CassandraConsistencyTaskSerializationModule;
import org.apache.james.modules.DistributedTaskManagerModule;
import org.apache.james.modules.DistributedTaskSerializationModule;
import org.apache.james.modules.MailboxModule;
import org.apache.james.modules.MailetProcessingModule;
import org.apache.james.modules.RunArgumentsModule;
import org.apache.james.modules.TasksCleanupTaskSerializationModule;
import org.apache.james.modules.blobstore.BlobStoreCacheModulesChooser;
import org.apache.james.modules.blobstore.BlobStoreConfiguration;
import org.apache.james.modules.blobstore.BlobStoreModulesChooser;
import org.apache.james.modules.data.CassandraDLPConfigurationStoreModule;
import org.apache.james.modules.data.CassandraDelegationStoreModule;
import org.apache.james.modules.data.CassandraDomainListModule;
import org.apache.james.modules.data.CassandraJmapModule;
import org.apache.james.modules.data.CassandraRecipientRewriteTableModule;
import org.apache.james.modules.data.CassandraSieveQuotaLegacyModule;
import org.apache.james.modules.data.CassandraSieveQuotaModule;
import org.apache.james.modules.data.CassandraSieveRepositoryModule;
import org.apache.james.modules.data.CassandraUsersRepositoryModule;
import org.apache.james.modules.data.CassandraVacationModule;
import org.apache.james.modules.event.JMAPEventBusModule;
import org.apache.james.modules.event.RabbitMQEventBusModule;
import org.apache.james.modules.eventstore.CassandraEventStoreModule;
import org.apache.james.modules.mailbox.CassandraDeletedMessageVaultModule;
import org.apache.james.modules.mailbox.CassandraMailboxModule;
import org.apache.james.modules.mailbox.CassandraMailboxQuotaLegacyModule;
import org.apache.james.modules.mailbox.CassandraMailboxQuotaModule;
import org.apache.james.modules.mailbox.CassandraQuotaMailingModule;
import org.apache.james.modules.mailbox.CassandraSessionModule;
import org.apache.james.modules.mailbox.DistributedDeletedMessageVaultModule;
import org.apache.james.modules.mailbox.TikaMailboxModule;
import org.apache.james.modules.mailrepository.CassandraMailRepositoryModule;
import org.apache.james.modules.metrics.CassandraMetricsModule;
import org.apache.james.modules.protocols.IMAPServerModule;
import org.apache.james.modules.protocols.JMAPServerModule;
import org.apache.james.modules.protocols.JmapEventBusModule;
import org.apache.james.modules.protocols.LMTPServerModule;
import org.apache.james.modules.protocols.ManageSieveServerModule;
import org.apache.james.modules.protocols.POP3ServerModule;
import org.apache.james.modules.protocols.ProtocolHandlerModule;
import org.apache.james.modules.protocols.SMTPServerModule;
import org.apache.james.modules.queue.rabbitmq.MailQueueViewChoice;
import org.apache.james.modules.queue.rabbitmq.RabbitMQMailQueueModule;
import org.apache.james.modules.queue.rabbitmq.RabbitMQModule;
import org.apache.james.modules.server.DKIMMailetModule;
import org.apache.james.modules.server.DLPRoutesModule;
import org.apache.james.modules.server.DataRoutesModules;
import org.apache.james.modules.server.InconsistencyQuotasSolvingRoutesModule;
import org.apache.james.modules.server.JMXServerModule;
import org.apache.james.modules.server.JmapTasksModule;
import org.apache.james.modules.server.JmapUploadCleanupModule;
import org.apache.james.modules.server.MailQueueRoutesModule;
import org.apache.james.modules.server.MailRepositoriesRoutesModule;
import org.apache.james.modules.server.MailboxRoutesModule;
import org.apache.james.modules.server.MailboxesExportRoutesModule;
import org.apache.james.modules.server.MessagesRoutesModule;
import org.apache.james.modules.server.RabbitMailQueueRoutesModule;
import org.apache.james.modules.server.SieveRoutesModule;
import org.apache.james.modules.server.UserIdentityModule;
import org.apache.james.modules.server.VacationRoutesModule;
import org.apache.james.modules.server.WebAdminMailOverWebModule;
import org.apache.james.modules.server.WebAdminReIndexingTaskSerializationModule;
import org.apache.james.modules.server.WebAdminServerModule;
import org.apache.james.modules.vault.DeletedMessageVaultRoutesModule;
import org.apache.james.modules.webadmin.CassandraRoutesModule;
import org.apache.james.modules.webadmin.InconsistencySolvingRoutesModule;
import org.apache.james.modules.webadmin.TasksCleanupRoutesModule;
import org.apache.james.queue.pulsar.module.PulsarQueueModule;
import org.apache.james.vault.VaultConfiguration;
import com.google.common.collect.ImmutableSet;
import com.google.inject.Module;
import com.google.inject.TypeLiteral;
import com.google.inject.name.Names;
import com.google.inject.util.Modules;
public class CassandraRabbitMQJamesServerMain implements JamesServerMain {
public static final Module WEBADMIN = Modules.combine(
new CassandraRoutesModule(),
new DataRoutesModules(),
new VacationRoutesModule(),
new DLPRoutesModule(),
new InconsistencyQuotasSolvingRoutesModule(),
new InconsistencySolvingRoutesModule(),
new JmapUploadCleanupModule(),
new UserIdentityModule(),
new JmapTasksModule(),
new MailboxesExportRoutesModule(),
new MailboxRoutesModule(),
new MailQueueRoutesModule(),
new MailRepositoriesRoutesModule(),
new SieveRoutesModule(),
new TasksCleanupRoutesModule(),
new WebAdminServerModule(),
new WebAdminReIndexingTaskSerializationModule(),
new MessagesRoutesModule(),
new WebAdminMailOverWebModule());
public static final Module PROTOCOLS = Modules.combine(
new CassandraJmapModule(),
new CassandraVacationModule(),
new IMAPServerModule(),
new LMTPServerModule(),
new ManageSieveServerModule(),
new POP3ServerModule(),
new ProtocolHandlerModule(),
new SMTPServerModule(),
new JMAPServerModule(),
new JmapEventBusModule(),
WEBADMIN);
public static final Module PLUGINS = new CassandraQuotaMailingModule();
private static final Module BLOB_MODULE = new BlobExportMechanismModule();
private static final Module CASSANDRA_EVENT_STORE_JSON_SERIALIZATION_DEFAULT_MODULE = binder ->
binder.bind(new TypeLiteral<Set<DTOModule<?, ? extends DTO>>>() {}).annotatedWith(Names.named(EventNestedTypes.EVENT_NESTED_TYPES_INJECTION_NAME))
.toInstance(ImmutableSet.of());
public static final Module CASSANDRA_SERVER_CORE_MODULE = Modules.combine(
new CassandraDelegationStoreModule(),
new CassandraDomainListModule(),
new CassandraDLPConfigurationStoreModule(),
new CassandraEventStoreModule(),
new CassandraMailRepositoryModule(),
new CassandraMetricsModule(),
new CassandraRecipientRewriteTableModule(),
new CassandraSessionModule(),
new CassandraSieveRepositoryModule(),
new TasksCleanupTaskSerializationModule(),
BLOB_MODULE,
CASSANDRA_EVENT_STORE_JSON_SERIALIZATION_DEFAULT_MODULE);
public static final Module CASSANDRA_MAILBOX_MODULE = Modules.combine(
new CassandraConsistencyTaskSerializationModule(),
new CassandraMailboxModule(),
new MailboxModule(),
new TikaMailboxModule());
public static final Module REQUIRE_TASK_MANAGER_MODULE = Modules.combine(
new MailetProcessingModule(),
CASSANDRA_SERVER_CORE_MODULE,
CASSANDRA_MAILBOX_MODULE,
PROTOCOLS,
PLUGINS,
new DKIMMailetModule());
protected static final Module MODULES = Modules.override(REQUIRE_TASK_MANAGER_MODULE, new DistributedTaskManagerModule())
.with(new RabbitMQModule(),
new RabbitMQEventBusModule(),
new DistributedTaskSerializationModule());
public static void main(String[] args) throws Exception {
ExtraProperties.initialize();
CassandraRabbitMQJamesConfiguration configuration = CassandraRabbitMQJamesConfiguration.builder()
.useWorkingDirectoryEnvProperty()
.build();
LOGGER.info("Loading configuration {}", configuration.toString());
GuiceJamesServer server = createServer(configuration)
.combineWith(new JMXServerModule())
.overrideWith(new RunArgumentsModule(args));
JamesServerMain.main(server);
}
public static GuiceJamesServer createServer(CassandraRabbitMQJamesConfiguration configuration) {
BlobStoreConfiguration blobStoreConfiguration = configuration.blobStoreConfiguration();
SearchConfiguration searchConfiguration = configuration.searchConfiguration();
return GuiceJamesServer.forConfiguration(configuration)
.combineWith(MODULES)
.combineWith(chooseMailQueue(configuration))
.combineWith(BlobStoreModulesChooser.chooseModules(blobStoreConfiguration))
.combineWith(BlobStoreCacheModulesChooser.chooseModules(blobStoreConfiguration))
.combineWith(SearchModuleChooser.chooseModules(searchConfiguration))
.combineWith(new UsersRepositoryModuleChooser(new CassandraUsersRepositoryModule())
.chooseModules(configuration.getUsersRepositoryImplementation()))
.combineWith(chooseDeletedMessageVault(configuration.getVaultConfiguration()))
.combineWith(chooseQuotaModule(configuration))
.overrideWith(chooseJmapModules(configuration));
}
private static Module chooseMailQueue(CassandraRabbitMQJamesConfiguration configuration) {
switch (configuration.getMailQueueChoice()) {
case PULSAR:
return new PulsarQueueModule();
case RABBITMQ:
return Modules.combine(
new RabbitMailQueueRoutesModule(),
new RabbitMQMailQueueModule(),
MailQueueViewChoice.ModuleChooser.choose(configuration.getMailQueueViewChoice()));
default:
throw new NotImplementedException();
}
}
private static Module chooseDeletedMessageVault(VaultConfiguration vaultConfiguration) {
if (vaultConfiguration.isEnabled() && vaultConfiguration.isWorkQueueEnabled()) {
return Modules.combine(
new DistributedDeletedMessageVaultModule(),
new DeletedMessageVaultRoutesModule());
}
if (vaultConfiguration.isEnabled()) {
return Modules.combine(
new CassandraDeletedMessageVaultModule(),
new DeletedMessageVaultRoutesModule());
}
return binder -> {
};
}
private static Module chooseJmapModules(CassandraRabbitMQJamesConfiguration configuration) {
if (configuration.isJmapEnabled()) {
return Modules.combine(new JMAPEventBusModule(), new JMAPListenerModule());
}
return binder -> {
};
}
private static Module chooseQuotaModule(CassandraRabbitMQJamesConfiguration configuration) {
if (configuration.isQuotaCompatibilityMode()) {
return Modules.combine(new CassandraMailboxQuotaLegacyModule(), new CassandraSieveQuotaLegacyModule());
} else {
return Modules.combine(new CassandraMailboxQuotaModule(), new CassandraSieveQuotaModule());
}
}
}