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

org.simplejavamail.mailer.internal.SendMailClosure Maven / Gradle / Ivy

/*
 * Copyright © 2009 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.mailer.internal;

import jakarta.mail.MessagingException;
import jakarta.mail.Session;
import lombok.val;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
import org.simplejavamail.api.email.Email;
import org.simplejavamail.api.internal.authenticatedsockssupport.socks5server.AnonymousSocks5Server;
import org.simplejavamail.api.mailer.EmailTooBigException;
import org.simplejavamail.api.mailer.config.OperationalConfig;
import org.simplejavamail.mailer.internal.util.TransportRunner;

import java.util.concurrent.atomic.AtomicInteger;

import static java.lang.String.format;
import static java.util.Optional.ofNullable;
import static org.simplejavamail.mailer.internal.MailerException.GENERIC_ERROR;
import static org.simplejavamail.mailer.internal.MailerException.MAILER_ERROR;
import static org.simplejavamail.mailer.internal.MailerException.UNKNOWN_ERROR;

/**
 * Separate closure that can be executed directly or from a thread.
 * 

* Note that this Runnable implementation is not thread related, it is just to encapsulate the code to * be run directly or from a real Runnable. */ class SendMailClosure extends AbstractProxyServerSyncingClosure { @NotNull private final OperationalConfig operationalConfig; @NotNull private final Session session; @NotNull private final Email email; private final boolean transportModeLoggingOnly; SendMailClosure(@NotNull OperationalConfig operationalConfig, @NotNull Session session, @NotNull Email email, @Nullable AnonymousSocks5Server proxyServer, boolean transportModeLoggingOnly, @NotNull AtomicInteger smtpConnectionCounter) { super(smtpConnectionCounter, proxyServer); this.operationalConfig = operationalConfig; this.session = session; this.email = email; this.transportModeLoggingOnly = transportModeLoggingOnly; } @Override public void executeClosure() { LOGGER.trace("sending email..."); try { if (transportModeLoggingOnly) { SessionBasedEmailToMimeMessageConverter.convertAndLogMimeMessage(session, email); LOGGER.info("TRANSPORT_MODE_LOGGING_ONLY: skipping actual sending..."); } else if (operationalConfig.getCustomMailer() != null) { val message = SessionBasedEmailToMimeMessageConverter.convertAndLogMimeMessage(session, email); operationalConfig.getCustomMailer().sendMessage(operationalConfig, session, email, message); } else { TransportRunner.sendMessage(operationalConfig.getClusterKey(), session, email); } } catch (final MessagingException e) { handleException(e, GENERIC_ERROR); } catch (final MailerException | EmailTooBigException e) { handleException(e, MAILER_ERROR); } catch (final Exception e) { handleException(e, UNKNOWN_ERROR); } } private void handleException(final Exception e, String errorMsg) { LOGGER.trace("Failed to send email {}\n{}\n\t{}", email.getId(), email, errorMsg); val emailId = ofNullable(email.getId()) .map(id -> format("ID: '%s'", id)) .orElse(format("Subject: '%s'", email.getSubject())); throw new MailerException(format(errorMsg, emailId), e); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy