All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.simplejavamail.smtpconnectionpool.SmtpClusterConfig Maven / Gradle / Ivy

/*
 * Copyright © 2019 Benny Bottema ([email protected])
 *
 * 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.simplejavamail.smtpconnectionpool;

import jakarta.mail.Session;
import jakarta.mail.Transport;
import lombok.Getter;
import lombok.NoArgsConstructor;
import lombok.ToString;
import org.bbottema.clusteredobjectpool.core.ClusterConfig;
import org.bbottema.clusteredobjectpool.core.ClusterConfig.ClusterConfigBuilder;
import org.bbottema.genericobjectpool.expirypolicies.TimeoutSinceLastAllocationExpirationPolicy;

import static java.util.concurrent.TimeUnit.SECONDS;

/**
 * Defines a preconfigured {@link ClusterConfig} builder with the following defaults:
 * 
    *
  • A specialized allocator factory for starting and stopping Transport connections ({@link TransportAllocatorFactory})
  • *
  • Expiration policy of {@value EXPIRY_POLICY_SECONDS} seconds, connections don't last long by default
  • *
  • Core pool size of {@value CORE_POOL_SIZE}, so objects are only created on-demand
  • *
  • Max pool size of {@value MAX_POOL_SIZE}
  • *
* * Configure further using {@code mySmtpClusterConfig.getConfigBuilder().x(a).y(b).z(c);} */ @Getter @ToString @NoArgsConstructor @SuppressWarnings("WeakerAccess") public final class SmtpClusterConfig { static final int CORE_POOL_SIZE = 0; static final int MAX_POOL_SIZE = 4; static final int EXPIRY_POLICY_SECONDS = 10; private final ClusterConfigBuilder configBuilder = ClusterConfig.builder() .allocatorFactory(new TransportAllocatorFactory()) .defaultExpirationPolicy(new TimeoutSinceLastAllocationExpirationPolicy<>(EXPIRY_POLICY_SECONDS, SECONDS)) .defaultCorePoolSize(CORE_POOL_SIZE) .defaultMaxPoolSize(MAX_POOL_SIZE); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy