1 /*
2  * Copyright (C) 2011 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 package com.android.tradefed.util;
18 
19 import java.io.IOException;
20 import java.util.ArrayList;
21 import java.util.Arrays;
22 import java.util.Collection;
23 
24 /**
25  * Interface for sending email.
26  */
27 public interface IEmail {
28 
29     /**
30      * A method to send a {@link Message}.  Verifies that the to, subject, and body fields of the
31      * {@link Message} are not null, but does no verification beyond the null checks.
32      *
33      * Note that any SMTP-level errors are undetectable at this stage.  Because of the asynchronous
34      * nature of email, they will generally be reported to the envelope-sender of the message.  In
35      * that case, the envelope-sender will typically receive an email from MAILER-DAEMON with the
36      * details of the error.
37      *
38      * @param msg The {@link IEmail.Message} to try to send
39      * @throws IllegalArgumentException if any of the to, subject, or body fields of {@code msg} is
40      *         null
41      * @throws IOException if sending email failed in a synchronously-detectable way
42      */
send(Message msg)43     public void send(Message msg) throws IllegalArgumentException, IOException;
44 
45     /**
46      * Container for email message data.
47      */
48     public static class Message {
49         static final String PLAIN = "text/plain";
50         static final String HTML = "text/html";
51 
52         private Collection<String> mToAddrs = null;
53         private Collection<String> mCcAddrs = null;
54         private Collection<String> mBccAddrs = null;
55         private String mSubject = null;
56         private String mBody = null;
57         private String mSender = null;
58         private String mContentType = PLAIN;
59 
Message()60         public Message() {}
61 
62         /**
63          * Convenience constructor: create a simple message
64          *
65          * @param to Single destination address
66          * @param subject Subject
67          * @param body Message body
68          */
Message(String to, String subject, String body)69         public Message(String to, String subject, String body) {
70             addTo(to);
71             setSubject(subject);
72             setBody(body);
73         }
74 
addTo(String address)75         public void addTo(String address) {
76             if (mToAddrs == null) {
77                 mToAddrs = new ArrayList<String>();
78             }
79             mToAddrs.add(address);
80         }
addCc(String address)81         public void addCc(String address) {
82             if (mCcAddrs == null) {
83                 mCcAddrs = new ArrayList<String>();
84             }
85             mCcAddrs.add(address);
86         }
addBcc(String address)87         public void addBcc(String address) {
88             if (mBccAddrs == null) {
89                 mBccAddrs = new ArrayList<String>();
90             }
91             mBccAddrs.add(address);
92         }
setSubject(String subject)93         public void setSubject(String subject) {
94             mSubject = subject;
95         }
96         /**
97          * Set the recipients. All previously added recipients will be replaced.
98          * {@link #addTo(String)} to append to the recipients list.
99          *
100          * @param recipients an array of recipient email addresses
101          */
setTos(String[] recipients)102         public void setTos(String[] recipients){
103             mToAddrs = Arrays.asList(recipients);
104         }
setBody(String body)105         public void setBody(String body) {
106             mBody = body;
107         }
setSender(String sender)108         public void setSender(String sender) {
109             mSender = sender;
110         }
setContentType(String contentType)111         public void setContentType(String contentType) {
112             if (contentType == null) {
113                 throw new NullPointerException();
114             }
115             mContentType = contentType;
116         }
117 
setHtml(boolean html)118         public void setHtml(boolean html) {
119             if (html) {
120                 setContentType(HTML);
121             } else {
122                 setContentType(PLAIN);
123             }
124         }
125 
getTo()126         public Collection<String> getTo() {
127             return mToAddrs;
128         }
getCc()129         public Collection<String> getCc() {
130             return mCcAddrs;
131         }
getBcc()132         public Collection<String> getBcc() {
133             return mBccAddrs;
134         }
getSubject()135         public String getSubject() {
136             return mSubject;
137         }
getBody()138         public String getBody() {
139             return mBody;
140         }
141 
getSender()142         public String getSender() {
143             return mSender;
144         }
145 
getContentType()146         public String getContentType() {
147             return mContentType;
148         }
149 
isHtml()150         public boolean isHtml() {
151             return HTML.equals(mContentType);
152         }
153     }
154 }
155