gobblin.util.EmailUtils.java Source code

Java tutorial

Introduction

Here is the source code for gobblin.util.EmailUtils.java

Source

/*
 * 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 gobblin.util;

import java.net.InetAddress;
import java.net.UnknownHostException;

import org.apache.commons.mail.Email;
import org.apache.commons.mail.EmailException;
import org.apache.commons.mail.SimpleEmail;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.google.common.base.Splitter;

import gobblin.configuration.ConfigurationKeys;
import gobblin.configuration.State;
import gobblin.password.PasswordManager;

/**
 * A utility class for sending emails.
 *
 * @author Yinan Li
 */
public class EmailUtils {

    private static final Logger LOGGER = LoggerFactory.getLogger(EmailUtils.class);

    /**
     * A general method for sending emails.
     *
     * @param state a {@link State} object containing configuration properties
     * @param subject email subject
     * @param message email message
     * @throws EmailException if there is anything wrong sending the email
     */
    public static void sendEmail(State state, String subject, String message) throws EmailException {
        Email email = new SimpleEmail();
        email.setHostName(state.getProp(ConfigurationKeys.EMAIL_HOST_KEY, ConfigurationKeys.DEFAULT_EMAIL_HOST));
        if (state.contains(ConfigurationKeys.EMAIL_SMTP_PORT_KEY)) {
            email.setSmtpPort(state.getPropAsInt(ConfigurationKeys.EMAIL_SMTP_PORT_KEY));
        }
        email.setFrom(state.getProp(ConfigurationKeys.EMAIL_FROM_KEY));
        if (state.contains(ConfigurationKeys.EMAIL_USER_KEY)
                && state.contains(ConfigurationKeys.EMAIL_PASSWORD_KEY)) {
            email.setAuthentication(state.getProp(ConfigurationKeys.EMAIL_USER_KEY), PasswordManager
                    .getInstance(state).readPassword(state.getProp(ConfigurationKeys.EMAIL_PASSWORD_KEY)));
        }
        Iterable<String> tos = Splitter.on(',').trimResults().omitEmptyStrings()
                .split(state.getProp(ConfigurationKeys.EMAIL_TOS_KEY));
        for (String to : tos) {
            email.addTo(to);
        }

        String hostName;
        try {
            hostName = InetAddress.getLocalHost().getHostName();
        } catch (UnknownHostException uhe) {
            LOGGER.error("Failed to get the host name", uhe);
            hostName = "unknown";
        }

        email.setSubject(subject);
        String fromHostLine = String.format("This email was sent from host: %s%n%n", hostName);
        email.setMsg(fromHostLine + message);
        email.send();
    }

    /**
     * Send a job completion notification email.
     *
     * @param jobId job name
     * @param message email message
     * @param state job state
     * @param jobState a {@link State} object carrying job configuration properties
     * @throws EmailException if there is anything wrong sending the email
     */
    public static void sendJobCompletionEmail(String jobId, String message, String state, State jobState)
            throws EmailException {
        sendEmail(jobState, String.format("Gobblin notification: job %s has completed with state %s", jobId, state),
                message);
    }

    /**
     * Send a job cancellation notification email.
     *
     * @param jobId job name
     * @param message email message
     * @param jobState a {@link State} object carrying job configuration properties
     * @throws EmailException if there is anything wrong sending the email
     */
    public static void sendJobCancellationEmail(String jobId, String message, State jobState)
            throws EmailException {
        sendEmail(jobState, String.format("Gobblin notification: job %s has been cancelled", jobId), message);
    }

    /**
     * Send a job failure alert email.
     *
     * @param jobName job name
     * @param message email message
     * @param failures number of consecutive job failures
     * @param jobState a {@link State} object carrying job configuration properties
     * @throws EmailException if there is anything wrong sending the email
     */
    public static void sendJobFailureAlertEmail(String jobName, String message, int failures, State jobState)
            throws EmailException {
        sendEmail(jobState, String.format("Gobblin alert: job %s has failed %d %s consecutively in the past",
                jobName, failures, failures > 1 ? "times" : "time"), message);
    }
}