01: //=============================================================================
02: //=== Copyright (C) 2001-2007 Food and Agriculture Organization of the
03: //=== United Nations (FAO-UN), United Nations World Food Programme (WFP)
04: //=== and United Nations Environment Programme (UNEP)
05: //===
06: //=== This program is free software; you can redistribute it and/or modify
07: //=== it under the terms of the GNU General Public License as published by
08: //=== the Free Software Foundation; either version 2 of the License, or (at
09: //=== your option) any later version.
10: //===
11: //=== This program is distributed in the hope that it will be useful, but
12: //=== WITHOUT ANY WARRANTY; without even the implied warranty of
13: //=== MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14: //=== General Public License for more details.
15: //===
16: //=== You should have received a copy of the GNU General Public License
17: //=== along with this program; if not, write to the Free Software
18: //=== Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
19: //===
20: //=== Contact: Jeroen Ticheler - FAO - Viale delle Terme di Caracalla 2,
21: //=== Rome - Italy. email: geonetwork@osgeo.org
22: //==============================================================================
23:
24: package org.fao.geonet.util;
25:
26: import org.apache.commons.mail.*;
27:
28: import jeeves.interfaces.Logger;
29: import jeeves.server.context.ServiceContext;
30: import jeeves.utils.Util;
31:
32: public class MailSender extends Thread {
33: Logger _logger;
34: SimpleEmail _mail;
35:
36: public MailSender(ServiceContext context) {
37: _logger = context.getLogger();
38: }
39:
40: public void send(String server, int port, String from,
41: String fromDescr, String to, String toDescr,
42: String subject, String message) {
43: _mail = new SimpleEmail();
44:
45: try {
46: _mail.setHostName(server);
47: _mail.setSmtpPort(port);
48: _mail.setFrom(from, fromDescr);
49: _mail.addTo(to);
50: _mail.setSubject(subject);
51: _mail.setMsg(message);
52:
53: start();
54: } catch (EmailException e) {
55: logEx(e);
56: }
57: }
58:
59: public void run() {
60: try {
61: _mail.send();
62:
63: _logger.info("Mail sent");
64: } catch (EmailException e) {
65: logEx(e);
66: }
67: }
68:
69: private void logEx(Exception e) {
70: _logger.error("Unable to mail feedback");
71: _logger.error(" Exception : " + e);
72: _logger.error(" Message : " + e.getMessage());
73: _logger.error(" Stack : " + Util.getStackTrace(e));
74: }
75: };
|