Refactor logging to fix NullPointerException.
3 * see AUTHORS for the list of contributors
5 * This program is free software: you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation, either version 3 of the License, or
8 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this program. If not, see <http://www.gnu.org/licenses/>.
19 package org.sonews.mlgw;
21 import java.io.BufferedOutputStream;
22 import java.io.BufferedReader;
23 import java.io.IOException;
24 import java.io.InputStreamReader;
25 import java.net.Socket;
26 import java.net.UnknownHostException;
27 import org.sonews.config.Config;
28 import org.sonews.storage.Article;
29 import org.sonews.util.io.ArticleInputStream;
32 * Connects to a SMTP server and sends a given Article to it.
33 * @author Christian Lins
39 protected BufferedReader in;
40 protected BufferedOutputStream out;
41 protected Socket socket;
43 public SMTPTransport(String host, int port)
44 throws IOException, UnknownHostException
46 socket = new Socket(host, port);
47 this.in = new BufferedReader(new InputStreamReader(socket.getInputStream()));
48 this.out = new BufferedOutputStream(socket.getOutputStream());
50 // Read helo from server
51 String line = this.in.readLine();
52 if(line == null || !line.startsWith("220 "))
54 throw new IOException("Invalid helo from server: " + line);
57 // Send HELO to server
59 ("HELO " + Config.inst().get(Config.HOSTNAME, "localhost") + "\r\n").getBytes("UTF-8"));
61 line = this.in.readLine();
62 if(line == null || !line.startsWith("250 "))
64 throw new IOException("Unexpected reply: " + line);
68 public SMTPTransport(String host)
77 this.out.write("QUIT".getBytes("UTF-8"));
84 public void send(Article article, String mailFrom, String rcptTo)
87 assert(article != null);
88 assert(mailFrom != null);
89 assert(rcptTo != null);
91 this.out.write(("MAIL FROM: " + mailFrom).getBytes("UTF-8"));
93 String line = this.in.readLine();
94 if(line == null || !line.startsWith("250 "))
96 throw new IOException("Unexpected reply: " + line);
99 this.out.write(("RCPT TO: " + rcptTo).getBytes("UTF-8"));
101 line = this.in.readLine();
102 if(line == null || !line.startsWith("250 "))
104 throw new IOException("Unexpected reply: " + line);
107 this.out.write("DATA".getBytes("UTF-8"));
109 line = this.in.readLine();
110 if(line == null || !line.startsWith("354 "))
112 throw new IOException("Unexpected reply: " + line);
115 ArticleInputStream artStream = new ArticleInputStream(article);
116 for(int b = artStream.read(); b >= 0; b = artStream.read())
121 // Flush the binary stream; important because otherwise the output
122 // will be mixed with the PrintWriter.
124 this.out.write("\r\n.\r\n".getBytes("UTF-8"));
126 line = this.in.readLine();
127 if(line == null || !line.startsWith("250 "))
129 throw new IOException("Unexpected reply: " + line);